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This  report  documents  the  functionality  available  using  Integrate  1.28,  a  Silicon  Graphics- 
based  software  package,  to  visualize,  analyze,  and  manipulate  three-dimensional  topographic  data. 
The  analysis  capability  represented  by  this  software  is  robust,  flexible,  and  instrumental  in 
applying  3-D  anthropometry  toward  the  improved  fit  of  protective  equipment,  clothing, 
commercial  head  gear,  and  medical  devices.  Tutorials  are  available  to  guide  the  user  through 
representative  applications. 
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PREFACE 


This  research  was  conducted  by  the  Computerized  Anthropometric  Research  and  Design  (CARD) 
Laboratory  of  the  Human  Engineering  Division,  Crew  Systems  Directorate,  Armstrong  Laboratory,  Wright- 
Patterson  Air  Force  Base,  Ohio.  The  work  was  performed  under  the  Scientific  Visualization  of 
Anthropometry  for  Research  and  Design  (SVARD)  Contract  Number  F41 624-93 -C-6001. 
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INTEGRATE  1.28:  A  Prototype  for  Evaluating  Three-Dimensional 
Visualization,  Analysis,  and  Manipulation  Functionality 

1.0  INTRODUCTION 

1.1  Background 

The  Computerized  Anthropometric  Research  and  Design  (CARD)  Laboratory,  Human  Engineering 
Division,  Armstrong  Laboratory  at  Wright-Patterson  Air  Force  Base,  Ohio  has  been  using  surface 
scanning  technology  to  improve  equipment  design  applications  since  1987.  CARD  Lab  researchers 
evaluated  many  commercial  software  packages,  such  as  Computer-Aided  Design  (CAD),  to  determine 
their  utility  for  manipulating  surface  data  for  USAF  equipment  designs.  These  software  programs, 
however,  proved  incapable  of  providing  the  unique  functions  required  to  analyze  topographic  data  on 
people  and  their  equipment.  For  this  reason,  the  CARD  Lab  developed  INTEGRATE  as  a  prototype 
system  to  test  the  functionality  required  to  visualize,  analyze,  and  manipulate  surface  data.  The  current 
version  of  INTEGRATE,  version  1 .28,  offers  new  functionality  to  meet  the  needs  of  current  USAF 
engineering  anthropometry  challenges.  With  Version  1.28,  additional  commands  have  been  added  to 
provide  virtual  anthropometric  tools  using  calipers  and  tape  (measure),  to  allow  registration  of  two 
objects  having  common  surface  areas  using  surf_reg,  to  reduce  an  object  in  size  uniformly  using  shrink, 
and  to  determine  the  distance  between  two  objects  using  clearance.  Researchers  from  businesses  and 
universities  worldwide  use  earlier  versions  of  INTEGRATE  to  test  and  evaluate  new  helmet  systems, 
develop  augmentative  files  such  as  landmark  data  or  contour  information  for  surface  scan  databases, 
record  human-equipment  interface  geometries,  extract  measurements  equivalent  to  traditional 
anthropometry  for  whole  body  image  data,  and  prepare  surface  data  for  rapid  prototyping  systems 
(Daanen  et  al.,  1996;  Brunsman  et  al.,  1996;  Brunsman  et  al.,  1996;  Robinette  et  al.,  1994;  Robinette  et 
al.,  1992;  Whitestone  et  al.,  1995;  Whitestone  et  al.,  1993;  Whitestone  et  al.,  1992). 

Because  INTEGRATE  was  designed  as  a  prototype,  user  friendliness  was  not  a  high  priority  for  the 
developers.  However,  a  few  hours’  experience  with  the  program  and  this  document  should  familiarize  the 
user  with  commonly  used  commands  and  the  general  architecture  of  the  software.  This  document 
contains  five  sections: 

1.  Introduction, 

2.  General  Operating  Instructions, 
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3.  Tutorials, 

4.  INTEGRATE  Commands, 

5.  INTEGRATE’S  Audit  Trail  Function,  and 

6.  Appendices. 

The  user  should  read  the  General  Operating  Instructions  before  beginning  the  Tutorials.  It  is  highly 
recommended  that  the  user  “walk  through”  through  at  least  the  first  two  tutorials  before  beginning  a  new 
session.  There  are  tutorials  that  are  targeted  for  users  of  both  head  scans  and  whole  body  surface  data. 
The  INTEGRATE  commands  are  organized  in  alphabetical  order  with  examples  of  the  use  of  each 
command.  Finally,  the  Appendices  are  included  to  provide  the  user  with  additional  information  such  as 
anatomical  landmark  definitions  and  illustrations,  listings  of  files  needed  for  the  tutorials,  and  batch  files 
for  routine  sessions. 

1.2  Functionality 

The  goal  in  the  design  of  INTEGRATE  is  to  provide  for  future  functions  so  that  no  changes  in  the  basic 
program,  functions,  and  data  structures  will  be  needed  to  add  any  new  function.  New  functions  can  and 
will  be  added  quickly  when  the  need  arises. 

1.3  Object  Pool 

The  Object  Pool  keeps  track  of  all  the  information  for  each  object.  INTEGRATE  can  work  with  an 
arbitrary  number  of  objects  at  one  time  (the  present  limit  is  "a  lot").  A  rule  of  thumb  is  that 
approximately  13  million  points  (100  head  scans)  can  be  in  the  Object  Pool  at  one  time.  These  objects 
can  be  displayed  or  hidden  by  the  user.  The  amount  of  memory  in  use  is  displayed  as  a  percentage  (13 
million  points  =  100%)  in  the  Global  Status  Window. 
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2.0  GENERAL  OPERATING  INSTRUCTIONS 


2.1  Starting  INTEGRATE 

INTEGRATE  was  originally  developed  on  the  Silicon  Graphics  4D  models.  While  the  CARD 
Laboratory  at  the  time  of  this  publication  is  using  Irix  6.2,  INTEGRATE  should  run  on  older  versions  of 
the  operating  system.  To  start  the  INTEGRATE  program,  login  to  the  Silicon  Graphics  system,  then  type 
integrate.  The  screen  will  show  the  X  and  Y  axes,  and  will  indicate  No  Active  Object  in  the  Active 
Object  Status  Window  in  the  lower  left  comer  of  the  screen. 

2.2  INTEGRATE  STATUS  WINDOWS 

INTEGRATE  has  3  status  windows  across  the  bottom  of  the  screen: 

the  Active  Object  Status  Window, 
the  Object  Summary  Window,  and 
the  Global  Status  Window. 


2.2.1  The  Active  Object  Status  Window,  located  in  the  lower  left  comer  of  the  screen,  contains 
information  about  the  current  Active  Object.  Many  INTEGRATE  commands  operate  on  the  Active 
Object,  so  it  is  important  to  view  the  current  status  of  an  object  before  modifying  it.  Figure  1  provides  an 
example  of  the  Active  Object  Status  Window. 


SubjFile:  101_53p 
LandFile:  1D1_53p. lnd 
Retire: 5  Lon  Thin:1  Lat 
Left :□  Right :512  Lower:0 
Rngles:  X:  13.4  V:  72.9 

Center:  X:  D.D  V:  2DD.1 

Offset:  X:  -4.2  V:  -61.9 


Thin :  1 
Upper : 256 
Z:  357.3 
Z:  0.0 

Z:  47.3 


Figure  1:  Active  Object  Status  Window 
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The  following  information  appears  in  the  Active  Object  Status  Window: 

•  SubjFile:  the  name  of  the  file  containing  the  original  data  points. 

•  LandFile:  the  name  of  the  file  containing  the  landmark  points. 

•  Active:  the  number  of  the  Active  Object  (this  object). 

•  Thin  Factors:  the  number  of  longitudes  and  latitudes  INTEGRATE  skips  when  displaying  the 
object. 

•  Comers:  the  Left  and  Right  longitudes  and  the  Lower  and  Upper  latitudes  of  the  subsection  of 
the  active  object. 

•  Angles:  the  X,  Y,  and  Z  rotation  angles  from  the  original  object  position  to  the  displayed  object 
position. 

•  Center:  the  X,  Y,  and  Z  offsets  to  center  the  object  in  the  axis  system. 

•  Offset:  the  X,  Y,  and  Z  offsets  to  move  the  object  from  its  original  (centered)  position  to  its 
displayed  position. 

2.2.2  The  Object  Summary  Window,  located  in  the  lower  right  comer  of  the  screen,  lists  every 
defined  object,  its  file  name,  and  its  display  status.  This  window  is  color-coded  to  help  determine  which 
image  in  the  display  area  is  associated  with  which  object.  Figure  2  provides  an  example  of  the  Object 
Summary  Window. 

Lslal  Is :  100:1400:1300 

Eye:  X:0  Y:0  Z:700  Dist:700 
Data  Path:  new_tut/ 
lieriory  Use:  11%  (1408K) 

PICK  OFF 


Figure  2:  Object  Summary  Window. 
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Each  object’s  summary  appears  in  this  order: 


(object  number)  (subject  file  name)  (display  status) 

The  object  number  is  the  number  to  use  to  select  that  object  for  use  in  a  command.  The  subject  file  name 
helps  determine  which  object  is  to  be  selected,  and  the  display  status  indicates  the  status  of  an  object. 

Table  1  below  defines  the  symbols  used  in  the  display  status  line: 


Symbol 

Meaning 

* 

This  is  the  active  object. 

+ 

This  object  is  on  the  screen  now,  not  hidden. 

W 

Wireframe  display  is  on  for  this  object. 

P 

Point  display  is  on  for  this  object. 

.  s 

Surface  display  is  on  for  this  object. 

T 

The  surface  display  for  this  object  is  transparent. 

1 

Landmark  display  is  on  for  this  object. 

c 

Contour  and  circumference  display  is  on  for  this  object. 

Table  1:  Display  status  line  definitions. 


2.2.3  The  Global  Status  Window  is  located  between  the  active  object  status  window  and  the  object 
summary  window.  The  global  status  window  contains  information  about  the  INTEGRATE  environment, 
such  as  eye  position,  pick  mode,  and  clipping  wall  locations.  Figure  3  provides  an  example  of  the  global 
status  window: 
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1  53psize5  +W 1 

2  10D_53ph  SI 

3  1 0D_53p  WI 

4  1D1_53ph 

5  1 01 _53p  *  S 

6  1 02_53ph  Ul 


Figure  3:  Global  status  window. 


7  1  D2_53p  iJSl 

8  104_53ph  Ul 

S  1 04_53p 
1 D  1 05_53ph  IJ 

11  1 D5_53p  Ul 


The  global  status  window  contains  the  following  information: 

•  Walls:  Clipping  Wall  positions  and  the  distance  between  them. 

•  Store:  If  Store  is  visible  on  line  1,  measurement  storage  is  enabled. 

•  R:  If  R  is  displayed  on  line  1,  RGB  (full  color)  mode  is  enabled. 

•  G:  If  G  is  displayed  on  line  1,  GOURAUD  shading  is  enabled  in  RGB  mode. 

•  Eye:  Eye  position  and  distance  with  respect  to  the  center  of  the  coordinate  system. 

•  Data  Path:  The  prefix  INTEGRATE  adds  to  a  load  command  file  name  to  locate  the  file. 

•  Memoiy  Use:  A  rough  estimate  of  the  percentage  of  the  available  memory  being  used  to  store  . 
object  information  (100  head  scans=100%). 

•  Pick  Mode:  Pick  mode  is  on  or  off. 

•  Orthogonal  View:  If  O  is  displayed  on  line  1,  orthogonal  view  is  enabled. 

•  Intrplnd:  If  *  is  displayed  next  to  pickmode,  intrplnd  is  enabled. 


2.3  Operating  Features 

INTEGRATE  has  a  number  of  operating  features  that  help  the  user  manipulate  displayed  data.  These 
include  the  echo  buffer,  use  of  the  up  and  down  arrow  keys,  point  picking,  and  toggle  options. 

2.3.1  The  Echo  Buffer  is  a  section  in  the  lower  left  comer  of  the  screen  which  displays  the  commands 
as  they  are  typed.  The  area  immediately  above  the  echo  buffer  displays  the  status  of  operations  in 
progress,  reports  operator  errors,  and  displays  command  usage  information  for  complex  commands.  The 
echo  buffer  also  supports: 
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•  the  Home  key  (go  to  start  of  command), 

•  the  End  key  (go  to  end  of  command), 

•  the  Delete  key  (delete  char  at  cursor), 

•  the  Backspace  (<-)  key  (delete  char  left  of  cursor), 

•  the  Insert  key  (insert  a  blank  at  the  cursor),  and 

•  the  left  and  right  arrow  keys  (move  cursor  without  changing  text). 


2.3.2  The  up/down  arrow  keys  recall  the  previous  command  in  the  command  history  list  to  the  echo 
buffer.  This  feature  is  circular;  when  the  oldest  available  command  is  displayed,  the  up  arrow  cycles  to 
a  blank  line,  then  repeats  starting  with  the  newest  command.  The  down  arrow  key  recalls  the  next 
command  in  the  command  history  list  to  the  echo  buffer. 


2.3.3  Point  Picking  consists  of  3  steps; 

1)  enabling  point  picking  (PICK  ON), 

2)  selecting  a  pick  mode  (PICKMODE),  and 

3)  picking  points  with  the  mouse  by  placing  the  cursor  and  clicking  the  left  mouse  button. 

The  INTEGRATE  cursor  is  the  same  size  as  the  pick  region,  so  the  points  within  the  cursor  boundaries 
will  be  picked  and  processed  according  to  the  pick  mode  when  the  left  mouse  button  is  pressed.  In  some 
pick  modes,  the  center  mouse  button  clears/resets  the  processing  for  that  mode.  For  example,  in  Pick 
Mode  CON3P,  if  the  center  mouse  button  is  pressed  after  the  second  point  is  picked,  the  Pick  Mode  will 
be  reset  to  restart  CON3P  picking,  with  the  next  point  being  used  as  point  1.  The  right  mouse  key  brings 
up  a  "popup"  menu  which  can  be  used  in  place  of  the  keyboard  for  many  of  the  INTEGRATE 
commands. 

The  available  function  keys  are  listed  across  the  top  of  the  screen.  These  keys  are  user-configurable 
through  a  file  called  fkey.tbl,  which  resides  in  the  INTEGRATE  directory.  The  INTEGRATE  directory 
is  accessed  through  an  environment  variable  called  INTEGRATE.  An  example  command  creating  this 
environment  variable  is:  "setenv  INTEGRATE  /home/code/INTEGRATE".  This  command  can  be 
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placed  in  the  user’s  .login  or  .cshrc  file  so  that  it  will  be  activated  when  the  user  logs  in.  If  the 
INTEGRATE  environment  variable  is  not  set,  the  MAN  command  will  not  work,  since  it  uses  the 
INTEGRATE  variable  to  find  the  users_guide  file,  which  contains  a  text  version  of  this  document. 

2.3.4  Toggle  Options 

Many  INTEGRATE  commands  enable  or  disable  screen  features  and  operating  modes.  A  toggle  option 
may  be  set  by  typing  <option  command>  on  ,  cleared  by  typing  coption  command>  off,  or  toggled  by 
typing  only  the  coption  comman>.  Most  toggle  options  are  tied  to  function  keys  which  is  where  the 
toggle  feature  is  most  valuable. 
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3.0  TUTORIALS 


INTEGRATE  supports  a  great  deal  of  functionality,  but  it  is  only  with  experience  that  the  user  will  be 
able  to  take  full  advantage  of  the  tools  available.  The  following  tutorials  lead  the  user  through  some 
common  INTEGRATE  activities  to  demonstrate  the  process  used  to  generate  the  end  result. 

The  image  data  and  batch  files  needed  for  these  tutorials  should  be  available  with  INTEGRATE  version 
1.28.  A  listing  of  the  necessary  files  for  each  tutorial  is  found  in  Appendix  A. 


To  see  the  end  result  of  each  tutorial,  run  the  tutorial  batch  files.  To  run  the  batch  file  for  the  first 
tutorial,  Basic  Moves,  type  this  command  in  INTEGRATE: 

@tutorial_l 

To  run  the  batch  file  for  the  second  tutorial.  Registration  Techniques,  type: 

@tutorial_2 

Each  tutorial  has  a  corresponding  batch  file.  To  gain  experience  with  the  INTEGRATE  commands, 
however,  new  users  should  execute  each  tutorial  step  by  step,  without  using  the  batch  files. 


The  tutorials  are  as  follow: 

Tutorial_l 

Tutorial_2 

Tutorial_3 

Tutorial_4 

Tutorial_5 

Tutorial_6 

Tutorial_7 

Tuturial_8 

Tutorial_9 

Tutorial_10 


Basic  Moves 
Registration  Techniques 
Point  Picking 
Feature  Envelopes 
Radial  Difference  Maps 
Helmet  Clearance 

Manipulating  Stereophotogrammetry  Data 
Manipulating  Whole  Body  Data  (Cyberware  WB4) 
Calipers/Tape  Measure 

Establishing  Joint  Centers  on  Whole  Body  Data 
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The  tutorials  are  presented  in  a  table  format.  Tutorial  steps  appear  in  the  left  column,  and  the  commands 
used  to  carry  out  each  step  appear  in  the  right  column.  Refer  to  section  4.0  Commands  for  additional 
information  on  how  the  commands  work. 
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3.1  Tutorial  One:  Basic  Moves 

This  tutorial  introduces  the  user  to  the  basic  commands  needed  to  manipulate  the  object  on  the  screen. 
The  user  will  learn  to  initially  position  the  object,  move  the  eyepoint,  turn  off  and  on  landmarks,  change 
the  representation  of  the  object  from  wireframe  to  surface,  and  other  essential  functions  for  visualizing 
the  image.  Shown  in  Figure  4  is  the  image  “010_53p”,  a  scan  of  an  unencumbered  subject  with  blue  dots 
indicating  the  location  of  anatomical  landmarks  (shown  here  in  monochrome). 


Figure  4:  Scan  of  an  unencumbered  subject  (shown  in  monochrome  for  this  publication). 
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The  files  needed  for  this  tutorial  are: 


010_53p 

010_53p.rgb 

010_53p.lnd 


Steps 

Commands 

1.  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Load  the  unhelmeted  scan  file  of  the  subject. 

cload  01 0_53p 

3.  .Load  the  anatomical  landmark  file  associated  with 
this  image. 

lload  010_53p.lnd 

4.  Rotate  the  subject  around  the  Y  axis  so  he  is  directly  facing  you. 
Notice  that  the  positive  Y  axis  value  causes  counterclockwise  rotation. 
This  rotation  initially  places  the  object  so  that  the  “front”  of  his  face 
is  facing  you.  This  coincides  with  the  default  eyepoint  of 

INTEGRATE  which  is  “front”.  All  subsequent  eyepoint  commands 
(e.g.  “back”)  will  correspond  with  the  object  (e.g.  back  of  the  head). 

The  axis  and  amount  of  rotation  will  depend  on  the  orientation  of  the 
object  when  scanned. 

rotate  0  75 

5.  Change  the  eyepoint  to  view  the  image  from  the  right.  Note  that 
this  does  not  MOVE  the  object,  it  only  changes  your  viewpoint. 

right 

6.  Change  the  eyepoint  to  view  the  image  from  the  back. 

back 

7.  Change  the  eyepoint  to  view  the  image  from  the  left. 

left 

8.  Change  the  eyepoint  to  view  the  image  from  the  top. 

top 

9.  Change  the  eyepoint  to  view  the  image  from  the  bottom. 

bottom 

10.  Change  the  eyepoint  to  view  the  image  from  the  front. 

front 

1 1.  Move  the  object  50  mm  along  the  x  axis.  Notice  that  the 
object  is  moving  relative  to  the  screen. 

move  50 

12.  Move  the  object  50  mm  along  the  y  axis.  Notice  that  the 
object  is  moving  relative  to  the  screen. 

move  0  50 

13.  Change  the  eyepoint  to  view  the  image  from  the  right. 

right 

14.  Move  the  object  50  mm  along  the  z  axis.  Notice  that  the 
object  is  moving  relative  to  the  screen. 

move  0  0  50 

15.  Move  the  object  back  to  the  original  origin. 

move  -50  -50  -50 

16.  Change  the  eyepoint  back  to  the  front.  ; 

front 

17.  Trim  away  extraneous  image  noise  at  the  top  and  bottom 
of  the  subject. 

trim  0  0  0  -55 

trim  0  0  55 
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Steps 

Commands 

18.  Make  a  copy  of  the  object  and  save  it  as  object  #2. 

copy  1  2 

19.  Create  voids  in  the  image  data. 

ruin  1  2 

20.  Hide  the  second  object. 

hide  2 

21 .  Fill  in  the  voids  on  the  image  and  the  gap  at  the  top  of  the 

1 

subject’s 

do  fill 

head.  Notice  that  “1”  was  first  selected  to  perform  the  operations  on 
the  first  object. 

toupee  200  205 

22.  Turn  off  the  axes  and  the  status  windows. 

axes 

boxes 

23.  Turn  the  status  windows  back  on  and  change  the  representation  of 

boxes 

the  landmark  locations  from  crosshairs  to  “L#”  with  the  number 

denoting  the  landmark  number  found  in  the  landmark  file.  See 

Appendix  C. 

altjand 

24.  Turn  on  the  landmark  list  to  view  the  active  landmarks  and  their 

coordinates  in  the  object  coordinate  system. 

landlist 

25.  Turn  off  the  landmark  list  and  turn  on  the  help  list. 

iandlist 

help 

26.  Turn  off  the  help  list  and  turn  on  the  function  keys  listing. 

help 

Turn  off  the  landmarks. 

fkeys 

27.  Turn  on  the  landmarks. 

land 

28.  Turn  off  the  wireframe  mode  and  apply  the  surface  routine  to  the 

wireframe 

object  to  show  texture  and  color. 

surface 

fullcolor  010_53p 

rgb 

29.  Calculate  the  volume  and  surface  area  of  the  object. 

volume 

surface_area 
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3.2  Tutorial  Two:  Registration  Techniques 


This  tutorial  demonstrates  registration  techniques  used  to  visualize  a  subject  within  a  helmet  system,  as 
shown  in  Figure  5.  This  registration  technique  can  be  used  for  examination  of  a  subject  within  any 
protective  equipment  item.  As  shown  in  Figure  5,  an  “x-ray”  view  is  provided,  allowing  the  designer  to 
look  inside  the  human-equipment  interface. 


Figure  5:  Registration  of  subject  with  helmet  scan  for  visualizing  subject/equipment  interface. 


Three  image  files  are  needed  for  the  registration  procedure: 


1)  one  scan  file  of  the  subject  with  at  least  three  visible  anatomical  landmarks, 

2)  one  scan  file  of  the  same  subject  expertly  fitted  with  a  helmet  system  and  showing  at  least  the 
same  three  anatomical  landmarks  plus  three  reference  landmarks  on  the  helmet  system,  and 

3)  one  scan  file  of  just  the  helmet  system  with  the  same  three  helmet  reference  landmarks. 

In  this  example,  the  landmarks  have  been  identified  and  saved  to  a  landmark  (*.lnd)  file  for  each  image 
file.  The  *.rgb  files  are  color  files  associated  with  each  scan.  The  files  used  in  this  tutorial  are: 

010_53p,  010_53p.rgb,  010_53p.lnd 
010_53ph,  010_53ph.rgb,  010_53ph.lnd 
53psize5,  53psize5.rgb,  53psize5.1nd 


Steps 

Commands 

1.  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Load  the  unhelmeted  scan  file  of  the  subject. 

cload  01 0_53p 

3.  Rotate  the  subject  around  the  Y  axis  so  he  is  directly  facing  you. 

Notice  that  a  positive  Y  axis  value  causes  counterclockwise  rotation. 

rotate  0  75 

4.  Trim  away  extraneous  image  noise  at  the  top  and  bottom  of  the 

subject. 

trim  0  0  0  -55 

trim  0  0  55 

5.  Fill  in  voids  on  the  subject  and  the  gap  at  the  top  of  the  subject’s 

head. 

do  fill 

toupee  200  205 

6.  Load  the  anatomical  landmark  file  associated  with  this  image. 

Hoad  010_53p.lnd 

7.  Load  the  helmeted  scan  file  of  the  same  subject  with  his  helmet 

donned. 

cload  010_53ph 

8.  Trim  the  noise  from  this  image. 

trim  0  0  0  -50 

trim  0  0  45  0 

9.  Load  the  landmark  file  associated  with  this  image. 

lioad  010_53ph.lnd 
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Steps  Commands 


10.  Register  the  helmeted  image  with  the  unhelmeted  image.  Notice 

that  the  second  image  is  rotated  and  translated  into  the  coordinate 

system  of  the  first  image,  and  that  lregister  is  used  to  align  the  scans 

as  the  common  landmarks  are  anatomical  landmarks. 

lregister  2  1 

11.  Change  the  viewpoint  to  view  the  images  from  the  right. 

right 

12.  Use  the  walls  command  to  “slice”  through  the  data  to  examine  the 

alignment  of  profiles. 

walls  695  699 

walls  +5 

walls  +5 

walls  full 

13.  Change  the  eyepoint  back  to  the  front. 

front 

14.  Load  the  helmet  scan  (and  landmark  file)  for  registration  with  the 

helmeted  image  file. 

cload  53psize5 

lload  53psize5.lnd 

15.  Register  the  helmet  scan  with  the  helmeted  image  file  and  view  the 

alignment.  Notice  that  zregister  is  used  to  align  the  scans  as  the 

common  landmarks  are  auxiliary  landmarks. 

zregister  3  2 

right 

walls  698  699 

walls  +5 

walls  +5 

16.  Hide  the  helmeted  scan  and  show  only  the  subject  and  the  scan  of 

the  helmet  alone.  This  final  configuration  illustrates  the  position  of  the 

subject  within  the  helmet. 

hide  2 

walls  full 

17.  Change  the  subject  file  to  a  surface  and  the  helmet  scan  to  a 

wireframe  of  lower  resolution. 

1 

wireframe 

surface 

3 

thin  2  2 

18.  Change  the  helmet  scan  to  a  transparent  surface. 

wireframe 

surface 

transparent 

19.  Change  the  subject  file  to  represent  the  color  information. 

fullcolor  010_53p 

rgb 

16 


17 


3.3  Tutorial  Three:  Point  Picking 


This  tutorial  demonstrates  how  to  access  and  implement  the  point  picking  capability  to  generate  a 
landmark  file  for  the  scan  data.  In  this  case,  a  head  scan  is  loaded  into  INTEGRATE  and  the  anatomical 
landmarking  sequence  initiated.  This  is  a  canned  landmarking  sequence  that  includes  42  head  and  face 
anatomical  landmarks.  The  landmark  selection  order,  shown  in  the  global  status  window,  has  been 
established  to  allow  the  user  to  begin  landmark  selection  on  the  right  side  of  the  head  and  progress 
around  the  head,  working  from  top  to  bottom.  The  actual  landmark  file,  however,  lists  the  landmarks  not 
in  the  order  of  selection,  but  in  the  order  found  in  Appendix  D.  If  a  new  landmark  picking  order  is 
required,  the  command  new_order  can  be  used  to  establish  a  order  for  picking  the  points.  Figure  6 
shows  a  head  scan  file  with  anatomical  landmarks. 


Figure  6:  Subject  scan  with  color  file  (monochrome  for  this  publication)  and  marked  landmark  locations. 
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User-defined  or  arbitrary  reference  landmarks  can  be  selected  and  stored  in  the  landmark  file  using  the 
command  pickmode  aux_land.  A  landmark  file  format  is  found  in  Appendix  D. 


Appendix  B  provides  an  illustration  of  the  head  and  face  anatomical  landmarks.  Refer  to  this  figure 
during  the  landmarking  process.  For  further  clarification,  definitions  of  the  landmarks  are  also  included 
in  Appendix  B.  The  landmark  to  be  picked  appears  in  the  Global  Status  Window. 

The  files  needed  for  this  tutorial  are: 

010_53p 

010_53p.rgb 

010_53p.lnd 


Steps 

Commands 

1.  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Load  the  head  scan  file. 

cload  010_53p 

3.  Trim  away  extraneous  image  noise  at  the  top  and  bottom  of  the 

subject. 

trim  0  0  0  -50 

trim  0  0  58 

4.  Fill  in  voids  on  the  subject  and  the  gap  at  the  top  of  the  subject’s 

head. 

do  fill 

toupee  200  205 

5.  Change  the  surface  from  wireframe  to  color  representation.  Color 

mode  clearly  displays  the  color  landmark  dots. 

wireframe 

surface 

fullcolor  010_53p 

rgb 

6.  Rotate  the  subject  to  the  right  to  prepare  for  landmark  selection. 

rotate  0  75 

7,  Begin  landmarking  session. 

pick  on 

pickmode  land 
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Commands 


Steps 

8.  Use  the  mouse  to  put  the  cursor  on  the  first  landmark  to  be  picked, 
the  right  tragion  (near  the  inner  ear;  refer  to  the  diagram  in  Appendix 
B).  Click  the  left  mouse  button  to  select  the  landmark.  Look  in  the 
global  status  window  for  the  prompt  that  lists  the  next  landmark  to  be 
picked.  Pick  several  more  landmarks. 

9.  Skip  backward  in  the  landmark  list  to  re-pick  the  last  landmark.  skip  -1 
When  the  prompt  in  the  global  status  window  changes  to  the  previous 
landmark  name,  re-pick  that  landmark. 

10.  Save  the  landmark  locations  to  a  landmark  file.  Iwrite  land_01 0.lnd 

11.  Display  the  landmark  list  to  view  the  landmark  coordinates.  landlist 

12.  Turn  off  the  landmark  list  and  turn  the  function  key  display  back  landlist 

on.  fkeys 

13.  Compare  the  selected  landmarks  with  the  standard  landmark  file  cload  010_53p  010_53p.lnd 

for  the  subject.  Load  the  subject  file  with  its  landmark  file  and  rotate  right 

it  into  the  same  orientation  as  the  original  subject.  rotate  0  75 

14.  Change  the  original  subject  back  to  wireframe  to  compare  the  1 

landmarks.  surface 

wireframe 

15.  Change  the  viewpoint  to  examine  the  scans  from  different  views.  front 

left 

back 

front 


3.4  Tutorial  Four:  Feature  Envelopes 


This  tutorial  demonstrates  how  INTEGRATE  can  be  used  to  generate  feature  envelopes  for  equipment 
items  such  as  a  helmet  system.  Feature  envelopes  describe  the  spatial  location  and  orientation  of  areas 
of  interest  (i.e.,  features)  with  respect  to  a  well  defined,  easily  duplicated  coordinate  system.  For  a  given 
helmet  system,  this  definition  could  include  the  range  of  pupil  location  along  all  three  coordinate  axes  or 
the  volume  which  contains  the  aggregate  of  all  ears  for  a  given  population. 

These  anthropometric  design  envelopes  defined  for  an  existing  helmet  are  based  on  one  critical  factor: 
the  relationship  of  the  head  to  the  helmet.  Helmet  systems  do  not  fit  the  human  head  in  exactly  the  same 
way  across  a  sample  of  people.  Figure  7  illustrates  two  subjects  wearing  the  same  helmet. 


Figure  7:  Two  subjects  wearing  the  same  size  and  model  helmet. 
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The  orientation  of  the  head  with  respect  to  the  helmet  system  is  entirely  dependent  on  the  shape  of  the 
helmet,  the  liner  system,  and  the  added  peripherals,  such  as  optics  or  earcups.  All  of  these  components 
must  be  fit  optimally  to  the  individual  and,  as  a  result,  the  helmet  system  "sits"  on  the  head  in  a  slightly 
different  manner  for  everyone.  In  order  to  study  these  anthropometric  design  issues,  researchers  need 
surface  scanning  combined  with  the  tools  available  in  INTEGRATE.  An  example  of  the  pupil  envelopes 
of  five  subjects  for  a  USAF  helmet  system  is  shown  in  Figure  8. 


Figure  8:  Pupil  envelopes  for  five  subjects  in  the  same  model  and  size  helmet. 

As  in  Tutorial  1,  this  tutorial  consists  of  aligning  an  encumbered  (helmeted)  scan  with  that  of  a  scan  of 
the  helmet  alone  and  aligning  the  unencumbered  (bare  head)  scan  with  that  of  the  helmeted  scan.  This  is 
performed  by  registration  of  the  helmet  landmarks  found  on  the  helmet  scan  with  common  landmarks 


22 


found  on  the  encumbered  scan  and  registration  of  anatomical  landmarks.  The  location  of  the  subject  can 
then  be  viewed  with  respect  to  the  helmet  coordinate  system.  Specifically,  the  locations  of  the  pupils  for 
each  subject  can  be  determined  with  respect  to  the  helmet  system.  This  is  performed,  in  this  tutorial,  for 
a  total  of  five  subjects. 

In  this  example,  the  landmarks  have  been  identified  and  saved  to  a  landmark  (*.lnd)  file  for  each  image 
file.  The  *.rgb  files  are  color  files  associated  with  each  scan. 

The  following  files  are  needed  for  this  tutorial: 

53psize5,  53psize5.rgb,  53psize5.1nd 
100_53p,  100_53p.rgb,  100_53p.lnd 
101_53p,  101_53p.rgb,  101_53p.lnd 
102_53p,  102_53p.rgb,  102_53p.lnd 
104_53p,  104_53p.rgb,  104_53p.lnd 
105_53p,  105_53p.rgb,  105_53p.lnd 
100_53ph,  100_53ph.rgb,  100_53ph.lnd 
101_53ph,  101_53ph.rgb,  101_53ph.lnd 
102_53ph,  102_53ph.rgb,  102_53ph.lnd 
104_53ph,  104_53ph.rgb,  104_53ph.lnd 
105_53ph,  105_53ph.rgb,  105_53ph.lnd 


Steps 

Commands 

1 .  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Load  the  helmet  scan  with  the  helmet  reference  landmarks. 

cload  53psize5  53psize5.lnd 

3.  Rotate  the  helmet  into  a  helmet-based  coordinate  system.  This 

coordinate  system  is  based  on  easily  located,  symmetric,  consistent 

reference  marks  on  the  helmet. 

align  xz  zl  z5  z3  z3 

4.  Load  the  first  subject’s  encumbered  (helmeted)  scan  with  landmark 

files  containing  both  helmet  reference  landmarks  and  anatomical 

landmarks. 

cload  100_53ph  100_53ph.lnd 

5.  Register  (align)  this  scan  with  the  helmet  scan  using  the  common 

helmet  landmarks. 

zregister  2  1 
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Steps  Commands 


6.  Load  the  first  subject’s  unencumbered  (bare  head)  scan  with 

anatomical  landmarks. 

cload  1 00_53p  100_53p.lnd 

7.  Register  (align)  this  scan  with  the  encumbered  scan.  In  effect,  this 

aligns  the  subject  with  the  helmet  scan. 

Iregister  3  2 

8.  Copy  the  pupil  landmark  locations  to  the  helmet  scan.  This 

associates  the  pupil  locations  with  respect  to  the  global  helmet 

system. 

1 

copyland  11  3  134 

copyland  12  3  138 

9.  Load  the  second  subject’s  encumbered  (helmeted)  scan  with 

landmark  files  containing  both  helmet  reference  landmarks  and 

anatomical  landmarks. 

cload  101_53ph  101_53ph.lnd 

10.  Register  (align)  this  scan  with  the  helmet  scan  using  the  common 

helmet  landmarks. 

zregister  4  1 

11.  Load  the  second  subject’s  unencumbered  (bare  head)  scan  with 

anatomical  landmarks. 

cload  101_53p  101_53p.lnd 

12.  Register  (align)  this  scan  with  the  encumbered  scan.  In  effect,  this 

aligns  the  subject  with  the  helmet  scan. 

Iregister  5  4 

13.  Copy  the  pupil  landmark  locations  to  the  helmet  scan.  This 

associates  the  pupil  locations  with  respect  to  the  global  helmet 

system. 

1 

copyland  13  5  134 

copyland  14  5  138 

14.  Load  the  third  subject’s  encumbered  (helmeted)  scan  with 

landmark  files  containing  both  helmet  reference  landmarks  and 

anatomical  landmarks. 

cload  101_53ph  101_53ph.lnd 

15.  Register  (align)  this  scan  with  the  helmet  scan  using  the  common 

helmet  landmarks. 

zregister  6  1 

16.  Load  the  third  subject’s  unencumbered  (bare  head)  scan  with 

anatomical  landmarks. 

cload  1 02_53p  102_53p.lnd 

17.  Register  (align)  this  scan  with  the  encumbered  scan.  In  effect,  this 

aligns  the  subject  with  the  helmet  scan. 

Iregister  7  6 

18.  Copy  the  pupil  landmark  locations  to  the  helmet  scan.  This 

associates  the  pupil  locations  with  respect  to  the  global  helmet 

system. 

1 

copyland  15  7  134 

copyland  16  7  138 
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Steps 

Commands 

19.  Load  the  fourth  subject’s  encumbered  (helmeted)  scan  with 

landmark  files  containing  both  helmet  reference  landmarks  and 

anatomical  landmarks. 

cload  104_53ph  104_53ph.ind 

20.  Register  (align)  this  scan  with  the  helmet  scan  using  the  common 

helmet  landmarks. 

zregister  8  1 

21 .  Load  the  fourth  subject’s  unencumbered  (bare  head)  scan  with 

anatomical  landmarks. 

cload  104_53p  104_53p.lnd 

22.  Register  (align)  this  scan  with  the  encumbered  scan.  In  effect,  this 

aligns  the  subject  with  the  helmet  scan. 

1  register  9  8 

23.  Copy  the  pupil  landmark  locations  to  the  helmet  scan.  This 

associates  the  pupil  locations  with  respect  to  the  global  helmet 

system. 

1 

copyland  17  9  134 

copyland  18  9  138 

24.  Load  the  fifth  subject’s  encumbered  (helmeted)  scan  with 

landmark  files  containing  both  helmet  reference  landmarks  and 

anatomical  landmarks. 

cload  105_53ph  105_53ph.lnd 

25.  Register  (align)  this  scan  with  the  helmet  scan  using  the  common 

helmet  landmarks. 

zregister  10  1 

26.  Load  the  fifth  subject’s  unencumbered  (bare  head)  scan  with 

anatomical  landmarks. 

cload  105_53p  105_53p.lnd 

27.  Register  (align)  this  scan  with  the  encumbered  scan.  In  effect,  this 

aligns  the  subject  with  the  helmet  scan. 

Iregister  11  10 

28.  Copy  the  pupil  landmark  locations  to  the  helmet  scan.  This 

associates  the  pupil  locations  with  respect  to  the  globed  helmet 

system. 

1 

copyland  19  11  134 

copyland  110  11  138 
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Steps 

Commands 

29.  Hide  all  objects  except  the  helmet  scan  with  the  pupil  feature 

hide 

2 

envelopes. 

hide 

3 

hide 

4 

hide 

5 

hide 

6 

hide 

7 

hide 

8 

hide 

9 

hide 

10 

hide 

11 

30.  View  the  pupil  envelopes  for  the  helmet  from  different 

right 

viewpoints. 

left 

back 

front 

3.5  Tutorial  Five:  Radial  Difference  Maps 


This  tutorial  demonstrates  how  a  combination  of  INTEGRATE  commands  can  be  used  to  quantitatively 
evaluate  the  radial  differences  between  cylindrical  surface  scans.  Given  two  scans,  the  differences  can 
be  calculated  along  each  radial  value  from  a  reference  scan  to  a  second  scan.  This  is  referred  to  as  a 
Radial  Difference  Map  (RDM).  For  this  example,  a  total  contact  bum  mask,  or  a  full  mask  which  covers 
the  entire  face,  is  compared  to  the  original  scan  data  of  the  subject  for  whom  the  mask  was  fabricated.  A 
radial  difference  map  indicates  the  degree  of  fit  of  this  mask  for  this  subject.  Figure  9  is  an  RDM  of  a 
subject’s  head  scan  and  a  scan  of  his  mask. 


Figure  9:  Radial  Difference  Map  (RDM)  of  the  total  contact  bum  mask,  with  respect  to  the  subject’s 
face.  Contrasting  colors  (monochrome  for  this  publication)  represent  different  degrees  of  fit. 
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NOTE:  For  this  example,  the  two  scans  have  been  registered  to  align  the  surfaces,  resampled  to 
transform  both  into  the  new  coordinate  system,  and  trimmed  to  the  same  values.  All  of  these  steps 
are  required  before  performing  a  radial  difference  map. 

In  this  example,  the  landmarks  have  been  identified  and  saved  to  a  landmark  (*.lnd)  file  for  each  image 
file.  The  *.rgb  files  are  color  files  associated  with  each  scan. 

The  following  files  are  needed  for  this  tutorial: 

face,  face.rgb 
mask,  mask.rgb 


Steps 

Commands 

1.  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Load  the  head  scan  file. 

cload  face 

3.  Move  the  scan  to  the  center  of  the  screen. 

move  0  200 

4.  Load  the  scan  of  the  subject’s  mask  and  move  it  to  the  center  of  the 

screen. 

cload  mask 

move  0  200 

5.  Perform  a  positive  subtraction  of  the  mask  with  respect  to  the  face. 
The  second  object,  scan  2,  will  be  replaced  by  the  subtraction  results. 

possub  1  2 

6.  For  the  radial  values  of  the  face  found  to  be  greater  than  those  of 
the  mask,  eliminate  all  difference  values  greater  than  1  mm. 

threshold  2  ge  1 

7.  Identify  these  radial  values  for  the  face  scan.  The  results  will  be 

saved  as  the  second  object. 

and  1  2 

8.  Perform  these  steps  again  using  another  scan  file  of  the  mask. 

cload  mask 

move  0  200 

9.  Perform  a  negative  subtraction  of  the  mask  with  respect  to  the  face. 
The  third  object,  scan  3,  will  be  replaced  by  the  subtraction  results. 

negsub  1  3 

10.  For  the  radial  values  of  the  face  found  to  be  less  than  those  of  the 

mask,  eliminate  all  difference  values  greater  than  1  mm. 

threshold  2  ge  1 

11.  Identify  these  radial  values  for  the  face  scan.  The  results  will  be 

saved  as  the  third  object. 

and  1  3 
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Steps 

Commands 

12.  Perform  these  steps  again  using  another  scan  file  of  the  mask. 

cload  mask 

move  0  200 

13.  Perform  a  positive  subtraction  of  the  mask  with  respect  to  the  face. 

The  fourth  object,  scan  4,  will  be  replaced  by  the  subtraction  results. 

possub  1  4 

14.  For  the  radial  values  of  the  face  found  to  be  greater  than  those  of 

the  mask,  eliminate  all  difference  values  less  than  1  mm. 

threshold  4  It  1 

15.  Identify  these  radial  values  for  the  face  scan.  The  results  will  be 

saved  as  the  fourth  object. 

and  1  4 

16.  Perform  these  steps  again  using  another  scan  file  of  the  mask. 

cload  mask 

move  0  200 

17.  Perform  a  positive  subtraction  of  the  mask  with  respect  to  the  face. 

The  fifth  object,  scan  5,  will  be  replaced  by  the  subtraction  results. 

negsub  1  5 

18.  For  the  radial  values  of  the  face  found  to  be  greater  than  those  of 

the  mask,  eliminate  all  difference  values  less  than  1  mm. 

threshold  5  It  1 

19.  Identify  these  radial  values  for  the  face  scan.  The  results  will  be 

saved  as  the  fifth  object. 

and  1  5 
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3.6  Tutorial  Six:  Helmet  Clearance 


This  tutorial  demonstrates  an  analysis  of  the  fit  of  a  PASGT  helmet  as  actually  worn  by  a  subject.  The  fit 
criterion  is  that  the  inner  surface  of  the  helmet  should  be  at  least  12.5  mm  from  the  head  at  all  points.  To 
test  this  criterion,  first  a  helmeted  scan  is  aligned  with  an  unhelmeted  scan,  then  the  helmet  alone  is 
aligned  with  the  helmeted  scan.  This  brings  the  bare  head  and  the  helmet  into  the  same  relationship 
observed  when  the  subject  was  wearing  the  helmet. 

To  approximate  the  inner  surface  of  the  helmet,  we  shrink  a  copy  of  the  helmet  outer  surface  9.4  mm, 
which  is  the  reported  thickness  of  the  PASGT  helmet.  This  is  not  exact,  since,  among  other  things,  the 
rivets  that  bulge  on  the  outside  of  the  helmet  would  also  bulge  inward  on  the  inside  of  the  helmet,  which 
is  not  true  of  our  approximated  inner  surface,  but  the  analysis  procedures  remain  the  same  when  a  more 
accurate  inner  surface  model  is  available. 

Note  also  the  surface  of  the  head  is  approximated  by  a  cap  placed  over  the  hair  to  compress  the  hair  and 
improve  the  visibility  of  the  laser  beam  during  scanning.  This  is  also  an  approximation,  and  to  be  more 
exact,  the  depth  of  the  cap  and  compressed  hair  should  be  determined  and  subtracted  from  the  scanned 
head  surface  before  checking  the  clearance. 

After  bringing  the  approximated  helmet  inner  surface  into  the  observed  relationship  with  the 
approximated  outer  head  surface,  we  begin  our  clearance  check. 

After  the  clearance  check  is  complete,  we  have  2  products:  a  new  object  which  represents  all  points  on 
the  head  closer  than  the  specified  clearance  criterion,  and  a  histogram  and  list  of  the  closest  point  on  the 
helmet  for  each  point  on  the  head.  The  surface  area  of  the  new  object  can  be  determined  as  a  measure  of 
the  fit  of  the  helmet  on  the  subject.  Similarly,  the  histogram  can  be  plotted  to  analyze  the  clearance 
distances  between  the  helmet  and  head. 
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Figure  10:  Picture  of  the  helmet  clearance  with  respect  to  the  subject’s  head  scan. 


In  this  example,  the  landmarks  have  been  identified  and  saved  to  a  landmark  (*.lnd)  file  for  each  image 
file,  “head”  files  are  of  the  unencumbered  scans,  “pasgt”  files  are  of  the  helmet  datasets,  and 
“head.pasgt”  are  of  the  head  in  the  helmet. 
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The  following  files  are  needed  for  this  tutorial: 

head.g,  head.lnd 
pasgt.g,  pasgt.lnd 
head.pasgt.cdd,  head.pasgt.lnd 
Files  produced  by  check_clearance  script: 

head.results  (list  of  closest  points  and  histogram  of  closest  distances) 
head.pasgt.fail.g  (dataset  with  all  head  points  failing  clearance  criterion) 


Steps 

Commands 

1 .  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Turn  off  the  wireframe  mode  and  turn  on  the  points  option  for  all 

subsequent  loaded  objects. 

option  wireframe  off 

option  points  on 

eye  0  0  1200 

3.  Load  unencumbered  head  scan. 

gload  head.g 

Hoad  head.lnd 

4.'  Load  outer  helmet  surface. 

gload  pasgt.g 

Hoad  pasgt.lnd 

5.  Load  helmet  head  scan  and  hide  this  image. 

cload  head.pasgt.cdd 

Hoad  head.pasgt.lnd 

hide 

6.  Register  the  helmeted  scan  to  the  head  scan  and  then  register  the 

helmet  with  the  helmeted  scan. 

Iregister  3  1 

zregister  2  3 

7.  Approximate  the  inner  helmet  surface  by  creating  another  helmet 

object  (object  #4). 

2 

movie_seg  - 

land  off 

shrink  9.4  0  0  0 

8.  Remove  irrelevant  points  from  head  scan  to  speed  things  up  and 

create  another  head  object  (object  #5). 

1 

movie_seg  lyl  1 0 

hide  1 

refresh 
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Steps 

Commands 

9.  Create  object  #6  which  compares  the  area  of  the  head  (object  #5) 

within  12.5  mm  of  inner  helmet  surface  (object  #4)  with  a  0.5  mm 

histogram  bin  size,  histogram  and  intermediate  results  stored  in 

head.results.  (This  operation  takes  about  an  hour  on  a  133-Mhz  SG 

Indy.  Plan  accordingly  .)  NOTE:  this  may  not  be  complete  due  to 

missing  data  at  top  of  head) 

clearance  4  .5  12.5  head.results 

10.  Store  object  containing  all  points  failing  clearance  criterion. 

gwrite  head.pasgt.fail.g 
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3.7  Tutorial  Seven:  Manipulating  Stereophotogrammetry  Data 

This  tutorial  demonstrates  the  commands  needed  to  manipulate  a  whole  body  scan  derived  from 
stereophotogrammetry  as  shown  in  Figure  11.  Stereophotogrammetry  was  used  in  the  1970’s  to  acquire 
whole  body  surface  data  (McConville,  et  al.,  1980).  Appendix  H  discusses  the  technique  used  to  isolate 
segment  data  from  the  stereophotogrammetry  image  files.  This  tutorial  allows  the  user  to  articulate  the 
body  segments  as  if  they  were  rotating  about  the  joint  axes.  Also  demonstrated  in  this  tutorial  is  the 


power  of  using  “superobjects”.  By  linking  all  of  the  body  segments  to  the  torso,  the  segments  can  either 
be  manipulated  independently  or  as  a  whole  body. 


Figure  11.  Example  of  a  male  subject  from  the  stereophotogrammetry  survey  in  the  seated  position. 
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The  files  used  in  this  tutorial  are: 

cs,  linkl,  sitl 

m2.1c,  m2.2c,  m2.3c,  m2.4c,  m2.5c,  m2.6c,  m2.7c,  m2.8c,  m2.9c,  m2. 10c, 
m2.11c,  m2.12c,  m2.13c,  m2.14c,  m2.15c,  m2.16c,  m2.17c,  m2.18c,  m2.19c, 
m2.1cs,  m2.2cs,  m2.3cs,  m2.4cs,  m2.5cs,  m2.6cs,  m2.7cs,  m2.8cs,  m2.9cs,  m2.10cs, 
m2.11cs,  m2.12cs,  m2.13cs,  m2.14cs,  m2.15cs,  m2.16cs,  m2.17cs,  m2.18cs,  m2.19cs, 
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Steps  I  Commands 


4.  Link  the  segments  of  the  stereo  data  to  the  torso  using  the  super 

object  command.  First  link  the  head  and  neck  to  the  torso. 

super  link  2  1 

super  link  3  2 

5.  Link  the  right  arm  to  the  torso. 

super  link  7  8 

super  link  6  7 

super  link  3  6 

6.  Link  the  left  arm  to  the  torso. 

super  link  10  11 

super  link  9  10 

super  link  3  9 

7.  Link  the  right  leg  to  the  torso. 

super  link  14  15 

super  link  13  14 

super  link  12  13 

super  link  5  12 

8.  Link  the  left  leg  to  the  torso. 

super  link  18  19 

super  link  17  18 

super  link  16  17 

super  link  5  16 

9.  Link  the  lower  torso  to  the  upper  torso. 

super  link  4  5 

super  link  3  4 

10.  Move  the  segments  of  the  body  into  a  seated  position.  Notice  that 
segment  3  is  the  torso  to  which  all  other  parts  are  anchored. 

3 

move  0  -80 

11.  Slightly  bend  torso  at  waist. 

5 

rotate  -10 

12.  Rotate  legs. 

12 

rotate  -80 

14 

rotate  90 

16 

rotate  -80 

18 

rotate  90 
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Steps 

Commands 

13.  Rotate  arms. 

6 

rotate  0  30 

7 

rotate  -90 

8 

rotate  0  -1 00 

9 

rotate  0  -30 

10 

rotate  -90 

11 

rotate  0  70 

14.  Turn  the  subject  to  the  right  and  rotate  the  entire  subject  360 

degrees. 

right 

rotate  0  30 

(repeat  this  1 1  times) 
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3.8  Tutorial  Eight:  Manipulating  Whole  Body  Data  (Cyberware  WB4) 


This  tutorial  demonstrates  visualization  and  manipulation  of  whole  body  scan  data.  The  format  of  the 
whole  body  image  is  considerably  different  from  head  scan  data  and  sometimes  requires  different 
commands  for  manipulating  this  object.  An  example  of  this  is  “eyepoint”.  To  view  the  entire  image,  the 
eyepoint  is  changed  from  the  default  value  of  700  mm  to  about  3000  mm.  This  allows  the  user  to 
visualize  the  whole  body  data  within  the  bounds  of  the  screen  axis  system.  Commands  to  segment  the 
whole  body  data  are  also  demonstrated  within  this  tutorial.  See  Figure  12. 


Figure  12:  Full  body  scan  data  with  the  body  segments  separated  from  the  torso. 
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The  files  needed  for  this  tutorial  are: 


drjxrff.g 

std.mtx 


Steps 

Commands 

1.  Clear  the  screen  of  axes,  boxes,  and  function  key  commands. 

axes  off 

boxes  off 

fkeys  off 

2.  Expand  the  walls  and  change  the  eyepoint  to  allow  full 

visualization  of  the  whole  body  image. 

walls  10  7000 

eyedist  3000 

3.  Move  the  eyepoint  to  the  front. 

front 

4.  Turn  the  wireframe  off  and  the  points  on. 

option  wireframe  off 

option  points  on 

5.  Load  the  image  file  and  a  transformation  matrix  to  position  it  in  the 

middle  of  the  screen.  From  this  viewpoint,  the  subject  is  viewed  from 

the  side. 

gload  dr_boff.g 

mload  std.mtx 

6.  To  view  the  object  from  the  front,  the  “eye”  command  is  used. 

eye  3700 

7.  Turn  on  the  pick  mode  and  move  the  subject  forward  slightly  so 

that  the  entire  object  can  be  seen. 

pick  on 

move  100  70 

8.  Turn  the  points  off  and  the  surface  on. 

points  off 

surface  on 

9.  Turn  the  surface  off  and  the  points  on. 

Notice  that  “off”  and  “on”  are  optional. 

surface 

points 

10.  Segment  the  left  arm.  Note:  object  #1  is  selected  before 

performing  the  next  operation. 

movie_seg  uz-234 

1 

11.  Segment  the  right  arm. 

movie_seg  Iz260 

1 

12.  Segment  the  head. 

movie_seg  Iy610 

1 

13.  Segment  the  torso. 

movie_seg  Iy120  uy609  lz-233  uz259 

1 
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Steps 

Commands 

14.  Segment  the  legs. 

movie_seg  uyl  1 9  lz-233  uz259 

15.  Hide  object  #1. 

hide  1 

16.  Move  the  body  segments  apart  from  the  torso. 

2 

move  0  0  -50 

3 

move  0  0  50 

4 

move  0  50 

6 

move  0  -50 
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3.9  Tutorial  Nine:  Calipers/Tape  Measure 


This  tutorial  demonstrates  the  use  of  virtual  calipers  and  tape  measure  on  the  whole  body  data  set.  For 
this  example,  a  whole  body  scan  is  loaded  into  INTEGRATE  and  the  calipers  are  used  to  measure  chest 
depth  and  the  tape  measure  is  used  to  record  waist  circumference  at  omphalion.  Shown  in  Figure  13  is 
the  whole  body  data  with  the  calipers. 


Figure  13:  Full  body  scan  data  with  the  virtual  calipers. 
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The  files  needed  for  this  tutorial  are: 


tsa_stda.ply,  std2.mtx 
c50x25.g 

calipers.g.color,  caliper.mtx,  waist_circ.mtx 


Steps 

Commands 

1.  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Establish  general  setup  options. 

rgb  on 

gouraud  on 

option  wireframe  off 

option  points  off 

option  surface  on 

3.  Load  a  whole  body  data  set. 

pload  tsa_stda.ply  -1000 

mload  std2.mtx 

4.  Load  a  caliper  object  and  turn  the  calipers  on. 

gload  c50x25.g 

fullcolor  calipers.g 

calipers  on 

5.  Orient  the  calipers  for  chest  depth  measurement  on  the  whole  body 

scan. 

mload  caliper.mtx 

jaw  2  1 50 

6.  Display  automatic  calipers. 

top 

autojaws  1 

7.  Set  walls  to  show  calipers. 

walls  640  643 

8.  Establish  cyberware  object  to  generate  circumference 

measurement.  Movie„seg  is  used  to  segment  the  torso  from  the  whole 

body  and  resample  is  used  to  create  a  cyberware  object  which  is 

compatible  with  commands  such  as  cir3p.  Note:  the  segmented  torso 

object  must  be  translated  such  that  the  y  axis  is  centered  in  the  middle 

of  the  torso.  This  is  to  ensure  that  the  resampled  object  has  a  uniform 

resolution. 

walls  full 

right 

movie_seg  uy40  ly-20 

hide  1 

hide  2 

top 

mload  waist_circ.mtx 

resample 

hide  3 
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Steps 

Commands 

9.  The  function  to  pick  points  is  now  turned  on  and  pickmode  cir3p  is 

pick  on 

selected  to  establish  a  horizontal  cut  plane  through  the  waist  to 

establish  a  contour  representative  of  waist  circumference. 

pickmode  cir3p 

10.  Use  the  mouse  to  put  the  cursor  at  the  location  of  the  first  (of 

three)  landmarks  to  be  picked.  These  are  points,  in  this  case,  selected 

by  the  user  to  represent  the  level  at  which  the  circumference  will  be 

taken.  Space  the  three  landmarks  horizontally  across  the  abdomen. 
Look  in  the  global  status  window  for  the  prompt  that  lists  the  next 
landmark  to  be  picked. 

11.  Change  the  view  to  see  the  contour  shape. 

top 

surface 

12.  Determine  the  distance  of  the  exact  contour.  Note:  “2”  in  this 

case  is  the  number  associated  with  the  contour.  This  number  may 
change  and  will  be  visible  with  the  contour.  (Hit  “space  bar”  after 
the  measurement  is  displayed.) 

distance  2 

13.  Now  determine  the  distance  of  the  contour  with  the  virtual  tape 

tape  2 

measure.  Notice  the  measurement  is  slightly  smaller  and  more 

representative  of  an  actual  tape  measure. 

distance  2 
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3.10  Establishing  Joint  Centers  on  Whole  Body  Data 


This  tutorial  demonstrates  the  ability  to  create  landmarks  representing  joint  centers  given  a  set  of 
anatomical  landmarks  located  on  a  whole  body  data  set.  The  joint  centers  are  estimates  and  are  assumed 
to  be  derived  from  landmarks  representing  bony  structures  on  the  body.  An  example  is  establishing  the 
knew  joint  as  the  midpoint  between  the  medial  and  lateral  femoral  condyles.  A  description  of  the  joint 
center  estimates  is  found  in  Appendix  I.  A  landmark  list  complete  with  illustrations  and  descriptions  is 
found  in  Appendix  C  .  Shown  in  Figure  14  is  the  whole  body  with  the  estimated  joint  center  locations. 


Figure  14:  Full  body  scan  data  with  the  estimated  joint  center  locations. 
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The  files  needed  for  this  tutorial  are: 

chrisla.ply 


chrisla.lnd,  std.mtx 


Steps 

Commands 

1.  Enter  INTEGRATE  and  begin  session. 

integrate 

2.  Load  the  whole  body  data  set  twice.  (One  object  is  to  associate 

with  the  anatomical  landmarks  and  the  other  is  to  associate  with  the 

joint  centers.) 

pload  chrisla.ply  -1000 

mload  std.mtx 

pload  chrisla.ply  -1000 

mload  std.mtx 

3.  Load  the  anatomical  landmarks  for  object  #2. 

Hoad  chrisla.lnd 

6.  Establish  the  head/neck  joint  center  and  copy  it  to  object  #1. 

split  11  z72  z64 

1 

copyland  11  2 11 

7.  Establish  the  neck/thorax  joint  center  and  copy  it  to  object  #1. 

copyland  12  2  z42 

add_to_land  12  0  -25  51 

8.  Establish  the  thorax/abdomen  joint  center  and  copy  it  to  object  #1. 

copyland  13  2  z43 

add_to_land  13  0  0  51 

9.  Establish  the  abdomen/pelvis  joint  center  and  copy  it  to  object  #1. 

copyland  14  2  z46 

add_to_land  14  0  0  51 

10.  Establish  the  right  shoulder  center  and  copy  it  to  object  #1. 

copyland  15  2  z74 

add_to_land  15  38  -38  0 

1 1 .  Establish  the  right  elbow  joint  center  and  copy  it  to  object  #1 . 

2 

split  16  z52  z51 

1 

copyland  16  2 16 

12.  Establish  the  right  wrist  joint  center  and  copy  it  to  object  #1. 

2 

split  17  z21  z54 

1 

copyland  17  2 17 
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Steps  Commands 


13.  Establish  the  left  shoulder  joint  center  and  copy  it  to  object  #1. 

copyland  18  2  z66 

addjojand  18  -38  -38  0 

14.  Establish  the  left  elbow  joint  center  and  copy  it  to  object  #1. 

2 

split  19  z57  z58 

1 

copyland  19  2  19 

15.  Establish  the  left  wrist  joint  center  and  copy  it  to  object  #1. 

2 

split  110  z23  z60 

1 

copyland  110  2  110 

16.  Establish  the  right  hip  joint  center  and  copy  it  to  object  #1. 

2 

split  111  z24  z17 

1 

copyland  111  2  111 

17.  Establish  the  right  knee  joint  center  and  copy  it  to  object  #1 . 

2 

split  112  z35  z36 

1 

copyland  112  2  112 

18.  Establish  the  right  ankle  joint  center  and  copy  it  to  object  #1. 

2 

split  113  z38  z78 

1 

copyland  113  2  113 

19.  Establish  the  left  hip  joint  center  and  copy  it  to  object  #1. 

2 

split  114  z24  z18 

1 

copyland  114  2  114 

20.  Establish  the  left  knee  joint  center  and  copy  it  to  object  #1 . 

2 

split  115  z27  z28 

1 

copyland  115  2  115 
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Steps 

Commands 

21 .  Establish  the  left  ankle  joint  center  and  copy  it  to  object  #1 . 

2 

split  116  z30  z70 

1 

copyland  116  2 116 

22.  Hide  object  #2  and  show  object  #1  with  the  estimated  joint 

centers. 

2 

hide 

1 

wireframe 

surface 

transparent 
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4.0  INTEGRATE  COMMANDS 


This  command  list  briefly  describes  the  INTEGRATE  commands  in  alphabetical  order.  Each  description 
explains  the  use  of  the  command  and  the  required  parts  of  the  command.  The  Usage,  Example,  and 
Result  section  of  each  description  demonstrates  how  to  set  up  a  command,  what  an  actual  command 
might  contain,  and  what  would  happen  in  INTEGRATE  if  the  example  command  was  executed.  In  the 
Usage  line,  parameters  that  appear  in  parentheses  ()  are  required;  parameters  that  appear  in  brackets  [] 
are  optional. 

Executing  commands 

Many  simple  INTEGRATE  commands  can  be  executed  with  the  function  keys.  The  function  key 
commands  appear  at  the  top  of  the  INTEGRATE  screen.  If  the  function  key  list  disappears,  press 
function  key  F7  to  display  it  again. 

Simple  commands  can  also  be  executed  by  pressing  the  right  mouse  key  and  selecting  the  command 
from  the  menu  windows. 

Commands  that  require  additional  parameters  (for  example,  the  distance  to  move  an  object  on  the 
screen)  must  be  executed  from  INTEGRATE’s  command  line.  The  command  line  is  at  the  bottom  left  of 
the  screen,  just  above  the  first  blue  information  box,  and  is  marked  by  a  flashing  cursor. 

Toggle  commands 

Toggle  commands,  such  as  wireframe,  surface,  and  land,  turn  INTEGRATE  features  on  or  off,  like  a 
light  switch.  For  example,  enter  wireframe  to  display  an  object’s  wireframe  and  enter  wireframe  again 
to  turn  off  the  wireframe  display. 

Nobody’s  Perfect 

INTEGRATE  is  a  powerful  software  tool,  but  it  has  some  limitations  of  which  the  novice  user  should  be 
aware: 
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1.  There  is  no  “undo”  command.  Once  an  INTEGRATE  command  is  entered,  it  has  to 
run  its  course.  The  INTEGRATE  operator  should  double-check  each  command  before 
executing  it. 

2.  INTEGRATE  is  not  case-sensitive.  Since  INTEGRATE  does  not  differentiate  between 
upper  and  lower-case  letters,  the  operator  should  type  commands  and  file  names  with 
lower-case  letters  only. 

3.  INTEGRATE  does  not  discriminate  between  file  types.  When  the  operator  mistakenly 
attempts  to  load  a  landmark  file  with  the  command  for  loading  an  image  file,  INTEGRATE 
tries  to  execute  the  command.  This  can  produce  unexpected  results,  but  it  provides  great 
flexibility  for  naming  files. 

4.  Perspective  commands  (front,  back,  and  side)  sometimes  need  adjustment.  When 
INTEGRATE  loads  an  image  file,  the  image  may  be  in  an  awkward  orientation.  In 
order  to  make  the  front,  back,  and  side  commands  work  correctly,  the  operator  should 
enter  the  front  command  and  then  use  rotate  commands  to  reorient  the  image.  Once  the 
image  is  oriented  correctly  for  one  perspective  command,  the  other  perspective 
commands  should  work  also. 
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LIST  OF  COMMANDS 


| 

$ 

@ 

abssub 

add 

add_to_land 

addobj 

align 

alt_land 

and 

autojaws 

avgland 

axes 

back 

balltest 

black 

bottom 

bottom_cap 

boxes 

calipers 

cd 

center 

centroid 

circumference 

clearance 

cload 

colors 

comment 

conclose 

contour 

contours 

copy 

copyland 

copyseg 

cursor 

cwrite 

cybermovie 

delete 

delland 

delpnt 

delseg 

delta 

derive 

diff 

dilate 

displace 

distance 

do  fill 

do  smooth 

drawline 

erode 


exit 

eye 

eyedist 

fcmod 

fcwrite 

fill 

filter 

filtseg 

fix_seam 

fkeys 

front 

fullcolor 

gcv 

gload 

gouraud 

gwrite 

help 

hide 

histogram 

interpolate 

intrplnd 

jaw 

jump 

land 

landlist 

left 

lload 

lregister 

lwrite 

man 

median 

merge 

mload 

mod  land 

move 

move_vertex 

movie_segment 

mwrite 

nameland 

negsub 

new_order 

newcenter 

newland 

option 

ortho 

pause 

pick 

pickmode 

planes 

pload 

points 


pop 

possub 

print 

push 

pwrite 

readout 

recolor 

refresh 

remark 

resample 

rgb 

right 

rotate 

ruin 

select 

set 

shad 

show 

shrink 

side 

skip 

sleep 

smooth 

split 

store 

subject 

super 

surf_reg 

surface 

surface_area 

tape 

text 

thin 

threshold 

top 

tops 

toupee 

transparent 

trim 

volume 

walls 

white 

wireframe 

wload 

w  write 

xload 

xwrite 

zload 

zregister 

zwrite 
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!<shell  command> 


$<shell  command> 


@<filename> 


abssub 


The  !  command  prefix  activates  a  UNIX  shell  command  from 
within  INTEGRATE,  either  from  the  command  line  or  from  a 
batch  file.  It  automatically  pushes  the  INTEGRATE  window 
so  the  user  can  see  other  windows  to  observe  actions  resulting 
from  the  command.  After  the  command  is  complete, 
INTEGRATE  pops  to  the  surface  when  the  user  presses  any 
key. 

The  $  command  prefix  activates  a  UNIX  shell  command  from 
within  INTEGRATE,  either  from  the  command  line  or  from  a 
batch  file.  It  does  not  change  any  window  configuration,  and 
it  does  not  wait  for  the  user  to  press  any  key  after  the 
command  is  completed. 

The  @  command  prefix  activates  a  batch  file  specified  by 
<filename>.  It  allows  commands  to  be  grouped  into  standard 
sequences  to  reduce  mental  gymnastics  and  repetitive  typing. 

A  command  file  (without  the  @)  can  also  be  specified  as  part 
of  the  command  line  that  starts  INTEGRATE.  For  example: 
“integrate  load52  spinfast”  starts  INTEGRATE,  loads,  trims, 
and  rotates  subject  52  (load52),  then  spins  the  viewer's  eye 
around  the  object  (spinfast). 

Command  files,  also  called  batch  files,  can  be  parameterized 
(e.g.  "@spinvar  2"  which  provides  a  parameter  of  2  to  the 
spinvar  command  file),  and  can  provide  a  limited  ability  to 
support  non-sequential  operations  such  as  looping  or 
if-then-else  constructs  (see  the  JUMP  command). 

This  command  performs  an  absolute  subtraction  on  two 
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objects  along  each  radial  value.  Specify  a  reference  object 
and  a  replace  object  of  the  same  size  (that  is,  with  the  same 
trim  values),  and  INTEGRATE  subtracts  one  object  from  the 
other.  The  second  object  is  subtracted  from  the  first  object, 
and  the  absolute  value  of  the  difference  is  retained. 
INTEGRATE  stores  the  subtraction  result  in  the  replace 
object.  It  is  recommended  that  the  objects  first  be  registered 
and  resampled  before  this  operation. 

Usage:  abssub  (reference  object)  (replace  object) 
Example:  abssub  1  2 

Result:  INTEGRATE  subtracts  object  2  from  object  1 
and  stores  the  result  in  object  2. 

add  This  command  performs  an  addition  on  two  objects.  The  user 

specifies  a  reference  object  and  a  replace  object  of  the  same 
size  (that  is,  with  the  same  trim  values),  and  INTEGRATE 
adds  the  objects  together.  INTEGRATE  stores  the  addition 
result  in  the  replace  object. 

Usage:  add  (reference  object)  (replace  object) 
Example:  add  1  2 

Result:  INTEGRATE  adds  objects  1  and  2  and  stores 
the  result  in  object  2. 

add_to_land  This  command  adds  an  XYZ  offset  in  the  screen  coordinate 

system  to  the  specified  standard  or  auxiliary  landmark  of  the 
active  object.  The  user  specifies  a  landmark  number  (for 
example,  L2  for  a  standard  landmark  or  Z2  for  an  auxiliary 
landmark)  and  an  offset  for  the  X-axis.  The  user  can  also 
specify  offsets  for  the  y  and  z  axes,  but  those  parameters  are 
optional.  An  example  of  this  function  would  be  to  find  the 
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mid-point  of  the  tragions  (using  the  split  command)  while  the 
head  is  aligned  in  the  Frankfurt  Plane  axis  system,  then  to  add 
Beier's  constant  (8.3, 0,  31.2  mm)  to  convert  the  landmark  to 
the  approximate  position  of  the  Center  of  Gravity  of  the  head. 

Usage:  add_to_land  (Z#/L#)  X  Y  Z 
Example:  add_to_land  z2  8.3  0  31.2 
Result:  The  auxiliary  landmark  z2  now  represents  the 
center  of  mass  location. 

addobj  This  command  replaces  a  section  of  the  grid  of  one  object 

with  the  same  grid  section  of  a  second  object.  Addobj  needs 
two  parameters:  the  object  to  be  modified  and  the  object  to  be 
added  to  the  specified  object. 

Usage:  addobj  (to  object)  (from  object) 

Example:  addobj  1  2 

Result:  Object  1  is  now  a  combination  of  objects  1 
and  2. 

align  This  command  aligns  an  object  to  the  screen  axis  system 

according  to  three  specified  landmarks  on  the  object.  When 
the  alignment  is  complete,  the  first  specified  landmark  will  be 
at  the  origin,  the  second  landmark  will  be  on  the  specified 
axis,  and  the  third  landmark  will  be  on  the  specified  plane.  If  a 
fourth  landmark  is  specified,  the  object  will  be  moved  to  the 
projection  of  the  fourth  landmark  on  the  specified  axis. 

Align  needs  from  four  to  nine  parameters: 

The  first  parameter  is  two  or  three  lower  case  characters, 
which  may  be  x,  y,  or  z.  The  first  character  of  the  first 
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parameter  is  the  name  of  the  axis  to  be  defined  by  the  first  two 
landmarks. 

The  second  character  of  the  first  parameter  is  the  name  of  the 
axis  perpendicular  to  the  first  axis,  and  on  the  plane  defined 
by  the  first  axis  and  the  third  landmark. 

The  third  character  of  the  first  parameter  is  the  name  of  the 
axis  along  which  the  object  will  be  shifted  if  a  fourth 
landmark  is  specified.  If  a  fourth  landmark  is  specified  but  a 
third  character  is  not,  INTEGRATE  shifts  the  object  along  the 
axis  defined  by  the  first  two  points. 

The  second  through  ninth  parameters  specify  landmarks  or 
longitude/latitude  coordinates.  Points  can  be  specified  by 
landmark  number,  either  standard  (L)  or  auxiliary  (Z),  or  by 
the  longitude  and  latitude  of  the  landmark.  Three  or  four 
points  must  be  specified.  These  points  define  the  axis  named 
above.  If  a  fourth  point  is  specified,  INTEGRATE  moves  the 
center  of  the  axis  system  along  the  axis  named  by  the  third 
character  of  the  first  parameter. 

Usage:  align  axislaxis2[axis3]  landl  land2  land3 
[land4] 

Example:  align  xy  11 12  13 
Result:  INTEGRATE  rotates  the  object  into  a 
coordinate  system  defined  as  follows:  the  X-axis 
passes  through  standard  landmarks  1  and  2,  the  Y-axis 
is  perpendicular  to  the  X-axis  passing  through 
standard  landmark  3,  and  the  Z-axis  is  defined  as  the 
cross  product  of  the  X  and  Y  axes.  The  origin  is 
defined  by  standard  landmark  LI. 
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alt_land  [on/off] 


and 


autojaws 


This  command  toggles  the  landmark  point  display  from  L#  or 
Z#  form  (landmarks  individually  labelled)  to  X  or  +  form 
(landmarks  marked  but  not  labelled).  The  X/+  form  reduces 
screen  clutter  when  landmark  labels  are  not  needed.  L#  or  X 
designate  "standard"  landmarks  (e.g.  Tragions  or 
Infraorbitale),  while  Z#  or  +  designate  "auxiliary"  landmarks, 
which  are  defined  only  for  a  specific  study. 

Usage:  toggle  command 
Example:  alt_land 

Result:  Landmarks  change  from  x  or  +  to  L#  or  Z#. 

This  command  performs  a  logical  AND  operation  on  two 
objects.  Points  with  a  value  of  zero  in  the  objects’  data  are 
considered  binary  zeros,  while  non-zero  values  are  considered 
binary  ones.  The  user  specifies  a  reference  object  and  a 
replace  object  of  the  same  size.  The  values  of  the  reference 
object  are  stored  in  the  replace  object  wherever  the  two 
objects  AND  to  a  binary  one. 

Usage:  and  (reference  object)  (replace  object) 
Example:  and  1  2 

Result:  Object  2  is  replaced  by  the  radial  values  of 
object  1  at  the  non-zero  radial  locations  of  object  2. 

This  command  automatically  performs  jaw  closure  on  a 
calipers  object  (set  as  the  active  object)  around  a  test  object 
(object  to  be  measured).  It  iteratively  moves  the  jaws,  then 
tests  for  intersection  (see  the  jaw  and  intersect  commands 
below).  It  requires  that  the  calipers  be  positioned  for  the 
measurement,  with  the  jaws  definitely  outside  of  (not 


55 


intersecting)  the  test  object.  It  positions  the  jaws  until  they 
are  within  "tolerance"  of  the  test  object  without  intersecting. 
If  "tolerance"  is  not  specified,  it  defaults  to  .001.  The 
"bounding_box"  value  is  the  distance  outside  the  edges  of  the 
bounding  box  for  the  calipers  in  which  points  are  still 
considered  for  the  intersection  test.  Limiting  this  test 
increases  the  speed  of  the  operation  dramatically.  If 
"bounding_box"  is  not  specified,  it  defaults  to  6.0  mm. 

Usage:  auto  jaws  <test_object>  [tolerance]  [bounding_box] 
Example:  auto  jaws  2  0.1  4.0 

Result:  The  calipers  jaws  are  closed  to  within  0.1  mm  of  the 
surface  of  object  2.  Only  the  object  2  points  within  4  mm  of 
the  bounding  box  of  the  calipers  are  considered  for  the 
intersection  test. 


avgland  This  command  averages  the  standard  landmark  sets  from  a 

selected  group  of  objects  to  produce  a  new  landmark  set 
which  represents  the  centroids  of  corresponding  landmarks. 
INTEGRATE  attaches  the  new  landmark  set  to  the  Active 
Object.  The  newly  defined  landmarks  can  be  left  as-is, 
meaning  that  they  stay  exactly  where  the  are  computed  to  be, 
or  they  can  be  projected  onto  the  surface  of  the  Active  Object. 

Avgland  requires  at  least  two  parameters:  (surf/asis)  and  a  list 
of  objects  to  be  included  in  the  average.  Note:  a  single 
landmark  set  may  be  copied  by  using  avgland  with  only  one 
object. 


Usage:  avgland  (surf/asis)  objl  obj2...  object# 

Example:  avgland  surf  12  3  4 

Result:  INTEGRATE  averages  the  standard 
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landmarks  of  objects  1,  2,  3,  and  4  and  projects  the 
averages  onto  the  surface  of  the  active  object. 


axes  [on/off] 


back 


balltest 


This  command  turns  the  X,  Y,  and  Z  axes  on  or  off. 

Usage:  toggle  command 
Example:  axes 

Result:  The  axes  appear  or  disappear. 

This  command  moves  the  user’s  “eye”  to  the  back  of  the 
object. 

Note:  The  object’s  coordinates  do  not  change.  When  back  is 
executed,  it  is  as  if  the  viewer  moved  behind  the  object  to  see 
the  back  of  it.  To  change  an  object’s  coordinates,  use  move  or 
rotate. 

Back  has  one  optional  parameter:  a  distance.  If  the  distance  is 
positive,  the  viewer’s  eye  will  be  positioned  that  much  further 
than  the  default  distance  (normally  700;  see  eyedist)  away 
from  the  object.  If  the  distance  is  negative,  the  viewer’s  eye 
will  be  positioned  that  much  closer  to  the  object. 

Usage:  back  [+/-number  of  mm] 

Example:  back  300 

Result:  The  viewer  sees  the  back  of  the  object,  300 
mm  further  away  from  it  than  before. 

This  command  evaluates  the  accuracy  of  the  Cyberware  head 
scanner  by  comparing  radii  computed  for  the  calibration  ball 
with  the  true  values.  Balltest  needs  one  parameter,  the  latitude 
to  use  for  the  radius  compare. 
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Use  pickmode  point  to  select  a  latitude  on  the  scan  of  the 
calibration  ball.  This  is  the  latitude  to  specify  in  the  balltest 
command. 

Usage:  balltest  (latitude) 

Example:  balltest  125 

Result:  INTEGRATE  computes  the  dimensions  of  the 
calibration  ball  and  displays  the  dimensions  in  the 
lower  left  comer  of  the  screen.  The  dimensions  should 
match  the  actual  dimensions  of  the  ball. 

black  This  command  sets  the  screen  background  color  to  black. 

Landmark  and  object  points  will  change  colors  so  that  they 
will  show  up  against  the  black  background. 

Usage:  black 
Example:  black 

Result:  The  screen  background  color  turns  black. 

bottom  This  command  moves  the  viewer's  eye  to  the  bottom  of  the 

object. 

Note:  The  object’s  coordinates  do  not  change.  When  bottom 
is  executed,  it  is  as  if  the  viewer  moved  under  the  object  to  see 
the  bottom  of  it.  To  change  an  object’s  coordinates,  use  move 
or  rotate. 

Bottom  has  one  optional  parameter:  a  distance.  If  the  distance 
is  positive,  the  viewer’s  “eye”  will  be  positioned  that  much 
further  than  the  default  distance  (normally  700;  see  eyedist) 
from  the  object.  If  the  distance  is  negative,  the  viewer’s  eye 
will  be  positioned  that  much  closer  to  the  object. 
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bottom_cap 


boxes  [on/off] 


calipers 


Usage:  bottom  [+/-  number  of  mm] 

Example:  bottom 

Result:  The  viewer  sees  the  bottom  of  the  object. 

This  command  fills  in  the  bottom  of  the  head  of  the  active 
object.  Note  that  this  command  works  best  when  the  object  is 
positioned  so  that  the  (estimated!)  lowest  point  on  the  head  is 
centered  about  the  Y  axis.  This  command  requires  one 
parameter:  the  lowest  latitude  to  establish  the  bottom  plane. 
Check  the  object  coordinates  in  the  blue  box  on  the  lower  left 
for  the  latitude  to  use  for  the  bottom  plane.  The  latitude  must 
be  within  the  current  trim  area. 

Usage:  bottom_cap  (latitude  to  establish  the  plane) 
Example:  bottom_cap  50 

Result:  INTEGRATE  fills  in  the  bottom  of  the  head 
scan  trimmed  at  lower  latitude  50 

This  command  turns  the  status  boxes  on  or  off.  This  can  be 
useful  for  making  snapshot/screen  dumps  or  for  increasing  the 
available  viewing  area  of  the  screen. 

Usage:  toggle  command 
Example:  boxes 

Result:  The  status  boxes  at  the  bottom  of  the  screen 
appear  or  disappear. 

This  command  is  used  to  turn  calipers  mode  on  and  off 
once  a  calipers  object  is  loaded.  Tutorial_9  demonstrates 
how  calipers  are  used  in  conjunction  with  the  caliper 
objects  and  commands  such  as  jaw,  auto_jaws,  and 
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readout. 

NOTE:  A  calipers  object  is  a  normal  object  representing  2 
jaws  and  a  slide  bar.  It  also  includes  some  special 
processing  which  is  only  active  when  calipers  mode  is  on. 

Usage:  toggle  command 

Example:  calipers 

Result:  Calipers  will  tum  on  or  off. 

cd  This  command  changes  the  directory  to  be  used  for  loading 

data  files. 

The  format  of  the  cd  command  is  "cd  <path>"  where  path 
is  a  standard  UNIX  path  descriptor,  such  as 
"/spare/anthro/data/minisurvey " . 

Usage:  cd  (path) 

Example:  cd  headfiles/survey 

Result:  The  directory  for  reading  data  files  changes 

to  /headfiles/survey. 

center  This  command  moves  the  active  object  to  put  the  specified 

point  at  the  center  of  the  axis  system.  There  are  two  forms 
of  the  command:  "center  xyz,"  which  names  the 
coordinates  of  the  point  to  be  centered,  and  "center  L#/Z#," 
which  names  the  landmark  (L  for  a  standard  landmark  or  Z 
for  an  auxiliary  landmark)  at  the  point  to  be  centered. 

Usage:  center  L#/Z# 

Example:  center  zl 

Result:  The  active  object  moves  so  that  auxiliary 
landmark  Zl  is  at  the  center  of  the  axis  system. 
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centroid 


circumference 


This  command  computes  the  centroid  of  either  the  standard 
landmarks  or  the  auxiliary  landmarks  and  stores  the  result 
in  the  specified  landmark  location.  Centroid  requires  two 
parameters:  the  landmark  to  hold  the  result  and  whether  to 
compute  the  centroid  of  the  standard  landmarks  (L  or  STD) 
or  the  auxiliary  landmarks  (Z  or  AUX). 

Usage:  centroid  (Z#/L#) 

(Z/L/aux/std) 

Example:  centroid  z3  aux 

Result:  INTEGRATE  computes  the  centroid  of  the 
auxiliary  landmarks  and  stores  the  resulting  centroid 
in  landmark  Z3. 

This  command  computes  a  circumference  line  completely 
around  the  object  where  a  plane  specified  by  either  three 
points  or  by  two  specified  points  and  the  center  of  the 
object  intersects  the  surface  of  the  object. 

Usage:  circum  (L#/Z#/lg  It)  (L#/Z#/lg  It)  [L#/Z#/lg 
It] 

Example:  circum  z2z3 
Result:  Integrate  creates  a  line  around  the 
circumference  of  the  object  on  the  plane  defined  by 
the  center  of  the  object  and  auxiliary  landmarks  2  and 
3. 

Circumference  accepts  its  parameters  in  a  variety  of  ways: 
any  of  the  two  or  three  specified  points  can  be  a 
longitude/latitude  coordinate  pair  <lon>  <lat>,  a  standard 
landmark  number  (L#),  or  an  auxiliary  landmark  number 
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(Z#). 


If  a  single  parameter  is  specified,  INTEGRATE  assumes  it 
is  either  a  latitude  or  a  landmark  to  use  as  a  latitude 
reference.  The  resulting  circumference  line  is  drawn  along 
the  specified  latitude  from  the  left  trim  limit  to  the  right 
trim  limit.  The  first  point  (leftmost  longitude)  is  repeated 
at  the  end  of  the  circumference  to  form  a  complete  circle. 

A  circumference  can  also  be  generated  by  picking  two  or 
three  points  (pickmode  cir2p  or  cir3p)  using  the  mouse  in 
point  picking  mode. 

clearance  clearance  -  This  command  determines  the  clearance  distances 

between  every  point  on  a  test  object  and  the  closest 
corresponding  point  on  a  reference  object.  It  produces  a 
dataset  made  up  of  all  points  closer  than  a  specified  threshold, 
and  a  text  file  containing  a  histogram  showing  the  distribution 
of  clearance  distances  for  the  entire  test  object.  The  test  object 
and  the  reference  object  must  be  mesh  objects,  and  the 
resulting  object  is  also  a  mesh  object. 

Clearance  takes  the  following  parameters: 
ref_obj  -  the  object  which  is  tested  against  the  active  object  to 
determine  clearances 

bin_size  -  the  resolution  of  the  clearance  histogram 
thresh  -  a  distance  below  which  a  point  is  considered  "too 
close".  Points  that  are  too  close  will  be  copied  to  a  new 
object  for  further  analysis.  If  thresh  is  not  specified,  no 
points  are  copied. 

result  -  the  name  of  a  file  in  which  to  store  the  detail  and 
histogram  information.  If  result  is  not  specified,  no 
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histogram  is  created. 


cload,  cloads* 


Usage:  clearance  ref_obj  bin_size  [thresh  [result]] 

Example:  clearance  1  0.5  12.5  clearance. results 
Result:  The  active  object  is  compared  to  object  1.  A 
histogram  of  clearance  distances  is  produced  in  file 
clearance.results  at  0.5  mm  resolution.  All  points  closer 
than  12.5  mm  will  be  copied  to  a  new  object  for  separate 
analysis. 

This  command  reads  in  a  scan  file.  Cload  has  four  optional 
parameters,  one  necessary  file  name,  and  one  optional  file 
name.  The  parameters  are: 

a,  for  an  ASCII  header; 

b,  for  a  binary  header; 

c,  if  there  is  a  color  file  associated  with  the  scan  file 
and  the  color  file  is  to  be  read  in;  and 

n,  if  there  is  no  color  file  or  if  you  don’t  want  to  load 
the  color  file. 

If  any  of  these  parameters  are  used,  group  them  together 
and  precede  the  first  parameter  with  a  (dash).  The 
current  default  is  binary  and  no  color  (-bn). 

After  the  parameters,  if  any,  type  the  name  of  the  scan  file 
to  be  read  in.  After  the  scan  file  name,  the  user  can  choose 
.  to  add  the  name  of  the  landmark  file  associated  with  the 
scan  file. 

Usage:  cload  [-abcn]  point_file  [land_file] 
Example:  cload  headscan  headscan.lnd 
Result:  INTEGRATE  reads  in  a  scan  file  called 


63 


*cIoads  is  used  for  loading 
in  stereophotogrammetry 
segment  data. 

colors 


headscan  and  its  associated  landmark  file, 
headscan.lnd. 


This  command  manipulates  the  object  color  table.  The 
colors  command  can  update  the  background  colors  or 
update  the  object  colors. 

Updating  the  background  colors  requires  the  following 
format: 

COLORS  0  background  text  box 
where: 

background=  the  background  color, 
text=  the  text  color, 

box=  the  background  color  of  the  information 
boxes. 

Updating  the  object  colors  requires  the  following  format: 

COLORS  n  bfeat  bpnts  wfeat  wpnts 

where: 

n=  the  object  number  to  change, 
bfeat=  the  color  for  features,  such  as  landmarks 
and  contour  lines,  when  the  background  is  black, 
bpnts=  the  color  for  points  and  wireframe  when  the 
background  is  black, 

wfeat=  the  color  for  features,  such  as  landmarks 
and  contour  lines,  when  the  background  is  white, 
wpnts=  the  color  for  points  and  wireframe  when 
the  background  is  white. 

The  available  colors  are: 

black  =  0  medium  gray  =  14 

red  =  1  bluish  red  =  15 
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green  =  2 
yellow  =  3 
blue  =  4 
magenta  =  5 
cyan  =  6 
white  =  7 
dim  red  =  8 
dim  green  =  9 
dim  yellow  =  10 
dim  blue  =11 
dim  magenta  =  12 
dim  cyan  =  13 


greenish  red  =  16 
bluish  green  =17 
reddish  green  =  18 
greenish  blue  =  19 
reddish  blue  =  20 
light  red  =  21 
light  green  =  22 
light  yellow  =  23 
light  blue  =  24 
light  magenta  =  25 
light  cyan  =  26 


Usage:  colors  object#  bfeat  bpnts  wfeat  wpnts 
or 

colors  0  background  textbox 
Example:  colors  1  22  24  5 

Result:  Object  1  changes  color.  When  the  background 
is  black,  points  and  wireframe  are  light  blue,  and 
landmarks  and  contour  lines  are  light  green.  When  the 
background  is  white,  landmarks  and  contour  lines  are 
magenta,  and  points  and  wireframe  are  dim  blue. 

comment  This  command  annotates  the  session  audit  trail  with  a  text 

string.  The  comment  appears  in  the  INTEGRATE  session 
record,  stored  in  the  directory  from  which  INTEGRATE 
was  launched. 

Usage:  comment  {string} 

Example:  comment  starting  new  session 
Result:  “starting  new  session”  appears  in  the 
INTEGRATE  session  record. 
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conclose 


This  command  closes  a  series  of  point-picked  contours 
using  pickmode  MUL2P  or  pickmode  MUL2A.  After  the 
contour  points  are  picked,  conclose  creates  the  contour  line 
between  the  first  and  last  points  picked. 

Usage:  conclose 
Example:  conclose 

Result:  INTEGRATE  completes  the  connected 
contours  by  drawing  a  contour  line  between  the  first 
and  last  points  picked. 


conclose  creates 
this  contour 
line 


point 


last 

point 


third 

point 


Figure  15:  Conclose  joining  the  first  and  last  selected  points. 


contour 


This  command  computes  a  contour  line  from  one  point  to 
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another  using  an  optional  third  point  or  the  object  center  to 
establish  the  plane  of  the  contour. 

Usage:  contour  [L#/Z#/lg  It]  [L#/Z#/lg  It] 

[L#/Z#/lg  It] 

Example:  contour  zl  z2 

Result:  INTEGRATE  draws  a  contour  line  on  the 
surface  of  the  active  object  that  connects  auxiliary 
landmarks  Zl  and  Z2  and  passes  through  the 
object’s  center. 

Contour  accepts  its  parameters  in  a  variety  of  ways:  any  of 
the  two  or  three  specified  points  can  be  a  longitude/latitude 
coordinate  pair  <lon>  <lat>,  a  standard  landmark  number 
(L<#>),  or  an  auxiliary  landmark  number  (Z<#>). 

If  a  single  parameter  is  specified,  INTEGRATE  assumes 
either  a  longitude  or  a  landmark  to  use  as  a  longitude 
reference.  INTEGRATE  draws  the  resulting  contour  line 
along  the  specified  longitude  from  the  lower  trim  limit  to 
the  upper  trim  limit. 

A  contour  can  also  be  generated  by  picking  two  or  three 
points  (pickmode  con2p  or  con3p)  using  the  mouse  in 
point  picking  mode.  Draw  a  connected  series  of  two-point 
contours  consecutively  by  using  pickmode  mul2p,  then 
picking  points.  With  this  pickmode,  the  endpoint  of  one 
contour  automatically  becomes  the  startpoint  of  the  next 
contour.  Pickmode  mul2a  also  creates  a  series  of  two-point 
contours,  but  instead  of  using  the  object  center  as  in  mul2p, 
it  uses  the  Z-axis  at  the  average  latitude  of  the  two  points 
for  its  third  point. 
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contours  [on/off] 


copy 


copyland 


This  command  turns  the  display  of  contour  lines  on  or  off. 

Usage:  toggle  command 
Example:  contours 

Result:  Contour  lines  appear  or  disappear. 

This  command  copies  one  object  to  another,  eliminating 
the  points  trimmed  from  the  first  object  and  keeping  only 
the  points  designated  by  the  first  object's  thin  factor. 

Copy  accepts  one  optional  parameter:  the  number  of  the 
object  to  be  copied.  If  no  object  number  is  specified,  the 
active  object  is  copied.  Copy  creates  a  new  object  in  the 
first  available  object  pool  slot. 

Usage:  copy  object 
Example:  copy  3 

Result:  INTEGRATE  creates  a  copy  of  object  3. 

This  command  copies  one  or  more  landmarks  from  one 
object  to  another.  Copyland  can  consolidate  landmarks 
from  two  or  more  sets  into  a  single  set.  An  example  might 
be  the  consolidation  of  the  Tragions  from  a  subject  data  set 
with  the  landmarks  from  a  helmet  scan  to  allow  analysis  of 
the  relationship  of  Tragions  to  helmet  position. 

Usage:  copyland  (Z#/L#)  (from  object)  (Z#/L#) 
[count] 

Example:  copyland  11  2 12  3 

Result:  INTEGRATE  copies  landmarks  2,  3,  and  4 

from  object  2  and  stores  them  in  landmarks  1,  2  and 
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3  on  the  active  object. 


copyseg 


cursor  [on/off] 


Copyland  operates  on  the  active  object  and  requires  three 
parameters:  the  destination  landmark  number  (Z#  or  L#), 
the  source  object  number,  and  the  source  landmark  number 
(Z#  or  L#).  An  optional  4th  parameter  specifies  the 
number  of  consecutive  landmarks  to  copy.  If  the  4th 
parameter  is  not  specified,  INTEGRATE  only  copies  the 
source  landmark. 

This  command  copies  the  area  of  an  object  bounded  by 
specified  contours  to  a  new  object.  Copyseg  needs  a  list  of 
contours  which  describe  the  segment  to  be  copied.  Each 
contour  displayed  on  an  object  is  numbered  at 
approximately  the  midpoint  of  the  contour.  Use  this 
number  in  specifying  contours  for  copyseg.  Two  special 
contours,  t  and  b,  are  used  to  specify  that  the  top  of  the 
object  or  the  bottom  of  the  object  is  to  be  used  as  a  contour 
boundary.  "Copyseg  t  b"  would  copy  the  entire  active 
object  (as  thinned  and  trimmed).  Copyseg  creates  a  new 
object  in  the  first  available  object  pool  slot. 

Usage:  copyseg  contourl...  contour# 

Example:  copyseg  12  3 

Result:  INTEGRATE  makes  a  copy  of  the  segment 

bounded  by  contours  1,  2,  and  3. 

This  command  enables  or  disables  a  surface  tracking 
cursor  for  the  active  object.  The  surface  tracking  cursor  is 
a  crosshair  that  conforms  to  the  contours  of  the  surface  of 
the  object. 
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cwrite 


cybermovie 


Note:  When  cursor  is  executed,  INTEGRATE  redraws  the 
screen  each  time  the  cursor  moves.  To  avoid  redraw 
delays,  use  the  cursor  command  with  wireframe  display, 
and  trim  the  object  before  executing  cursor. 

Usage:  toggle  command 
Example:  cursor 

Result:  The  surface  tracking  cursor  appears  or 
disappears. 

This  command  writes  out  a  (new)  Cyberware-format  file. 
Cwrite  requires  a  new  filename  as  a  parameter.  It  always 
writes  the  data  with  the  new/modified  ASCII  header. 

Usage:  cwrite  filename 
Example:  cwrite  face_scan 
Result:  INTEGRATE  writes  the  data  in  the  active 
object  to  a  new  file  called  face_scan.  INTEGRATE 
stores  the  file  in  the  directory  from  which 
INTEGRATE  was  launched. 

This  command  copies  a  cyberware  object  into  a  new 
object,  converting  it  to  a  MOVDE.BYU  representation. 
Cybermovie  works  on  the  active  object  only,  and  requires 
one  parameter:  whether  the  object  is  completely  closed 
(WRAP)  or  is  a  partial  surface  (NOWRAP).  This 
parameter  determines  whether  INTEGRATE  creates 
polygons  to  connect  the  object’s  last  longitude  to  the  first 
longitude. 

Usage:  cybermovie  (wrap/nowrap) 

Example:  cybermovie  wrap 
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Result:  INTEGRATE  creates  a  copy  of  the  active 
object  in  MOVIE.BYU  format.  INTEGRATE 
stores  the  file  in  the  directory  from  which 
INTEGRATE  was  launched. 

delete  This  command  removes  one  or  more  objects  from  the 

object  pool  or  one  or  more  sub-objects  from  an  object. 
Delete  needs  one  parameter,  which  is  either  the  number  of 
the  object  to  be  removed  or  a  range  of  objects  to  removed 
(e.g.  DELETE  1-10).  After  objects  have  been  removed, 
new  objects  can  be  read  in  to  replace  them. 

If  two  or  more  parameters  are  specified,  the  first  is  the 
object  (or  objects)  to  be  modified,  and  the  subsequent 
.  parameters  are  the  sub-objects  to  be  deleted  from  the 
specified  object.  The  object  itself  is  not  removed  when 
two  or  more  parameters  are  specified. 

Usage:  delete  [object] 

Example:  delete  3 

Result:  INTEGRATE  removes  object  3  from  the 
object  pool. 

delland  This  command  deletes  a  landmark  value  from  the  standard 

landmark  list.  The  slot  in  the  list  remains,  but  the 
coordinates  of  the  landmark  are  zeroed.  Delland  requires 
one  parameter,  the  standard  or  auxiliary  landmark  number 
of  the  landmark  to  delete  (L#  or  Z#). 

Usage:  delland  (Z#/L#) 

Example:  delland  zl3 

Result:  INTEGRATE  deletes  the  landmark  value 
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stored  in  auxiliary  landmark  Z13. 


delpnt  This  command  deletes  (voids)  one  point  from  the  data  set. 

Delpnt  accepts  its  parameter(s)  in  a  variety  of  ways:  the 
point  can  be  specified  as  a  longitude/latitude  coordinate 
pair  <lon>  <lat>,  a  standard  landmark  number  (L#),  or  an 
auxiliary  landmark  number  (Z#).  Points  can  also  be 
deleted  by  picking  points  with  the  mouse  when  pickmode 
is  set  to  delpnt. 

Usage:  delpnt  (Z#/L#)  or  delpnt  <lon>  <lat> 
Example:  delpnt  z24  or  delpnt  189  56 
Result:  INTEGRATE  deletes  the  point  at  auxiliary 
landmark  Z24  or  the  point  at  longitude  1 89, 
latitude  56. 

delseg  This  command  deletes  (voids)  all  of  the  points  within  the 

boundaries  of  a  specified  set  of  contours.  Delseg  needs  a 
list  of  contours  which  describe  the  segment  to  be  deleted. 
Each  contour  displayed  on  an  object  is  numbered  at 
approximately  the  midpoint  of  the  contour.  Use  this 
number  in  specifying  contours  for  delseg.  Two  special 
contours,  t  and  b,  are  used  to  specify  that  the  top  of  the 
object  or  the  bottom  of  the  object  is  to  be  used  as  a  contour 
boundary.  "Delseg  t  b"  would  delete  all  of  the  points  in  the 
entire  active  object  (as  thinned  and  trimmed). 

Usage:  delseg  contour  1...  contour# 

Example:  delseg  2-6 

Result:  INTEGRATE  deletes  the  region  defined  by 
contours  2  through  6  from  the  active  object. 
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delta 


This  command  colors  the  surface  of  an  object 
according  to  its  distance  from  a  reference  object. 

Points  on  the  object  with  larger  radii  are  shown  in 
yellow,  fading  to  red  with  increasing  distance. 

Points  on  the  object  with  smaller  radii  are  shown  in 
cyan,  fading  to  blue  with  increasing  distance.  Delta 
needs  one  parameter:  the  number  of  the  reference 
object.  It  always  operates  on  the  active  object.  If 
no  reference  object  is  specified,  the  distance  for 
color-coding  is  computed  from  the  mean  radius  of 
the  active  object. 

Usage:  delta  reference_obj 
Example:  delta  3 

Result:  The  color  of  the  active  object  changes  to 
reflect  its  distance  from  object  3. 

derive  This  command  derives  a  missing  landmark  from  a  second 

landmark  and  the  resultant  from  combining  the  two 
landmarks.  Derive  needs  three  parameters  and  has  two 
optional  parameters.  The  required  parameters  are  a 
destination  landmark  number  (Z#  or  L#),  the  resultant 
landmark  number  (Z#  or  L#),  and  the  other  landmark  used 
to  produce  the  resultant  (Z#  or  L#).  You  can  specify  an 
optional  total  weight  and  second  landmark  weight  if  the 
resultant  was  produced  with  unequal  weights. 

Suppose  you  want  to  create  a  new  landmark,  Z3,  between 
landmarks  LI  and  L6. 

•  LI  •  Z3  •  L6 
You  would  use  split  to  create  Z3,  the  resultant 
landmark.  If  data  is  lost  and  L6  disappears 
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you  can  recreate  it  with  derive.  To  recreate  L6,  type 
derive  L6  Z3  LI 

If  you  used  weighting  in  the  split  operation,  you  could 
use  weighting  in  the  derive  command,  also. 

Usage:  derive  (Z/L  destination  landmark#)  (Z/L 
landmark  1)  (Z/L  landmark  2)  [weight  1]  [weight 
2] 

Example:  derive  z5  L28  L14  5  .5 
Result:  INTEGRATE  recreates  landmark  Z5,  using 
5  as  a  total  weight  and  0.5  as  a  second  landmark 
weight. 

This  command  displays  and  prints  the  difference  between 
the  rotation  angles  of  two  scans.  The  displayed  difference 
is  the  difference  to  rotate  one  scan  into  the  axis  system  of 
the  other  scan.  This  command  ignores  any  offset 
differences  due  to  different  centers  of  rotation.  It  requires 
two  parameters:  the  "final"  object  and  the  "beginning" 
object.  For  example,  DIFF  1  2  provides  the  angles 
necessary  to  rotate  object  2  into  the  same  orientation  as 
object  1 .  The  display  and  print  show  the  angular  rotation 
around  the  X  axis,  the  Y  axis,  and  the  Z  axis.  If  the 
rotation  around  the  Z  axis  is  significant,  the  other  two 
angles  may  be  slightly  in  error. 

Usage:  diff  obj  1  obj2 
Example:  diff  1  2 

Result:  INTEGRATE  displays  and  prints  the  angles 
needed  to  rotate  object  2  into  the  same  orientation 
as  axis  1. 


dilate  This  command  performs  a  morphological  dilation  on  an 

object.  After  an  object  has  been  eroded,  dilate  completes 
the  smoothing  process.  Dilate  expands  the  data  so  that  a 
structuring  element  with  an  origin  placed  at  the  original 
data  fits.  The  structuring  element  used  in  this  instance  is  a 
cylinder  with  a  spherical  top.  The  user  specifies  the  radius 
of  the  sphere  or  both  the  cylinder  and  the  sphere.  (If  only 
the  sphere  is  specified,  the  cylinder  is  set  to  the  same 
radius.)  The  default  dilation  operation  is  positive.  A 
negative  dilation  can  be  performed  by  adding  the  modifier 
"minus." 


displace 


distance 


Usage:  dilate  (sphere  size)  [cylinder  size] 

[MINUS] 

Example:  dilate  5  2 

Result:  If  erode  has  already  been  executed, 
INTEGRATE  smoothes  the  active  object. 

This  command  applies  the  present  displacement  matrix  for 
a  MOVIE.BYU  object  to  each  point,  then  resets  the 
displacement  matrix  to  the  identity  matrix  (no  rotations  or 
translations).  This  allows  a  permanent  change  of  axis 
system  when  the  object  is  written  out  (see  GWRITE). 

Usage:  displace  object 
Example:  displace  3 

Result:  The  next  time  object  3  is  loaded,  it  will 
appear  in  the  same  position  it  was  in  when  displace 
was  executed.  INTEGRATE  assigns  that  position 
to  the  object. 

This  command  computes  the  total  surface  distance  along 
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do  fill 


do  smooth 


drawline 


either  contours  or  circumferences  of  the  active  object. 
Distance  requires  a  list  of  contours  or  circumferences  to  be 
measured.  Each  contour  displayed  on  an  object  is 
numbered  at  approximately  the  midpoint  of  the  contour.  Use 
this  number  in  specifying  contours.  Distance  computes  the 
contour  distance  for  each  contour  and  displays  the  sum  of 
all  the  distances. 

Usage:  distance  contourl...  contour# 

Example:  distance  3  5 

Result:  INTEGRATE  displays  the  surface  distance 
of  contours  3  and  5. 

This  command  replaces  void  points  in  the  active  object 
with  an  approximation  based  on  surrounding  points. 

Usage:  do  fill 
Example:  do  fill 

Result:  INTEGRATE  fills  in  missing  points  on  the 
active  object. 

This  command  replaces  each  point  in  the  active  object’s 
data  set  with  the  average  value  of  the  point  and  its 
neighbors,  resulting  in  smoother  data  surfaces. 

Usage:  do  smooth 
Example:  do  smooth 

Result:  INTEGRATE  smoothes  the  surface  of  the 
active  object. 

This  command  draws  a  straight  line  from  one  landmark 
through  another  landmark,  with  an  optional  length 
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specified.  Drawline  requires  two  parameters:  the  landmark 
at  the  origin  of  the  line  (Z#  or  L#),  and  a  landmark  that  the 
line  is  to  pass  through.  An  optional  length  parameter 
specifies  the  length  of  the  line.  If  length  is  not  specified, 
the  line  ends  at  the  2nd  landmark. 

Usage:  drawline  (L#/Z#)  (L#/Z#)  [length] 

Example:  drawline  LI  L32 

Result:  INTEGRATE  draws  a  line  connecting 

landmarks  1  and  32. 

erode  This  command  performs  a  morphological  erosion  on  an 

object.  Erosion  shrinks  the  data  so  that  the  origin  of  a 
structuring  element  fitted  within  the  data  becomes  the  new 
location  for  a  data  point.  The  structuring  element  used  in 
this  instance  is  a  cylinder  with  a  spherical  top  (see  figure 
16  below).  The  user  specifies  the  radius  of  the  sphere  or 
both  the  cylinder  and  the  sphere.  If  only  the  sphere  is 
specified,  the  cylinder  is  set  to  the  same  radius.  The  larger 
the  sphere  and  cylinder,  the  greater  the  erosion  that  occurs. 
The  default  erosion  operation  is  positive.  A  negative 
erosion  can  be  performed  by  adding  the  modifier  "minus". 
(An  opening  is  an  erode  followed  by  a  dilate.) 

Usage:  erode  (sphere  size)  [cylinder  size]  [minus] 
Example:  erode  4  5 

Result:  INTEGRATE  takes  the  “sharp  edges”  off  the 
data.  To  complete  the  smoothing  process,  execute 

dilate. 
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This  command  ends  INTEGRATE.  Pressing  FI 2  or 
selecting  the  exit  command  from  the  right  mouse  key  menu 
also  ends  INTEGRATE. 

Usage:  exit 
Example:  exit 

Result:  The  INTEGRATE  session  ends  when  the 
user  presses  Shift  Y. 

This  command  changes  the  perspective  from  which  the 
user  views  the  active  object.  Eye  does  not  change  the 
object’s  position  in  the  axis  system;  rather,  the  viewer’s 
“eye”  moves  to  the  front,  side,  top,  or  bottom  of  the  object. 

Eye  needs  three  parameters,  the  X,  Y,  and  Z  location  of  the 
eye.  Eye  0  700  0  puts  the  viewer’s  eye  on  top  of  the 
object.  Eye  0  0  700  puts  the  viewer’s  eye  in  front  of  the 
object.  Eye  700  0  0  puts  the  viewer’s  eye  beside  the 
object. 


Usage:  eye  (distance  along  X  in  mm)  (distance 


along  Y  in  mm)  (distance  along  Z  in  mm) 

Example:  eye  0  0  300 

Result:  Your  “eye”  moves  300  mm  along  the  Z 
axis,  much  closer  to  the  active  object. 

eyedist  This  command  resets  the  default  eye  distance  to  the 

specified  distance.  The  default  distance  is  set  at  700. 

When  it  is  changed,  the  front,  back,  left,  side,  right, 
bottom,  and  top  commands  use  the  new  distance  as  the 
default  distance  for  computing  eye  position. 

Usage:  eyedist  (distance) 

Example:  eyedist  300 

Result:  The  eye  distance  is  set  to  300.  When  a 
perspective  command  (front,  right,  top,  etc.)  is  executed,  the 
viewer’s  “eye”  is  300  mm  from  the  object. 

fcmod  This  command  separately  removes  all  red,  green,  and  blue 

color  components  which  fall  outside  of  the  specified 
boundaries. 

Usage:  fcmod  {UIL}  {RIGIB}  <value>  [...] 

Example:  fcmod  LR32  UR  128 

Result:  All  red  components  below  32  or  above  128  are  set 
to  0,  removing  the  red  component  from  that  surface  point. 

fcwrite  This  command  writes  out  an  ASCII  fullcolor  (24-bit)  file. 

It  requires  a  single  argument  which  is  the  base  name  of  the 
file  to  be  written  to.  The  suffix  “.color”  is  appended  to  the 
base  name. 

Usage:  fcwrite  filename 
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fill  [on/offj 


filter 


filtseg 


Example:  fc write  head 

Result:  A  file  called  head.color  is  created  which 
contains  the  green,  and  blue  color  components  for 
each  vertex. 

This  command  enables  or  disables  automatic  void  fill  for 
an  object  after  a  command,  such  as  cload  or  resample, 
which  might  create  new  voids  in  the  data. 

Usage:  toggle  command 
Example:  fill 

Result:  INTEGRATE’s  fill  function  is  enabled  or 
disabled. 

This  command  filters  the  data  with  one  of  the 
INTEGRATE  smoothing  filters.  Select  a  type  of  smoothing 
filter  and  a  scale  factor  to  determine  the  strength  of  the 
filter.  (The  larger  the  scale,  the  larger  the  number  of 
adjacent  points  involved  in  the  filter  function.)  Options 
are:  GAUSSIAN,  DISCRETE,  or  GREEN  filters.  The  filter 
may  be  applied  latitudinally,  longitudinally  or  in  both 
directions.  Note:  When  using  filter  on  a  trimmed  area, 
points  outside  the  area  are  used  in  calculations.  This  may 
result  in  shrinkage  from  the  rest  of  the  data.  See  filtseg. 

Usage:  filter  (GAUSS/DISCRETE/GREEN)  scale 
(LAT/LON/BOTH) 

Example:  filter  gauss  3  lat 

Result:  INTEGRATE  smoothes  the  active  object. 

This  command  is  identical  to  the  filter  command  except  that 
the  edge  of  a  trimmed  area  is  replicated  and  used  in  place  of 
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data  outside  the  area.  This  helps  to  prevent  shrinkage. 


Usage:  filtseg  {GAUSS/DISCRETE/GREEN}  scale 
{LAT/LON/BOTH} 

Example:  filtseg  gauss  3  lat 

Result:  INTEGRATE  smoothes  the  active  object. 

fix_seam  •  This  command  corrects  any  mismatch  between  the  sides  of 

the  seam  where  the  end  of  the  data  set  meets  the  beginning. 
The  mismatch  is  caused  by  subject  movement  during  the 
scan.  Fix_seam  operates  on  the  active  object  only.  Note: 

For  best  results,  make  sure  the  object’s  trim  boundaries 
correspond  with  the  physical  seam. 

Usage:  fix_seam  (active  object) 

Example:  fix_seam 

Result:  INTEGRATE  corrects  seam  mismatch  in  the 
active  object. 


fkeys  This  command  turns  the  function  key  display  on  or  off.  It 

works  the  same  as  the  other  toggle  commands. 


Usage:  toggle  command 
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Example:  fkeys 

Result:  The  function  key  display  at  the  top  of  the 
screen  appears  or  disappears. 

front  This  command  moves  the  viewer’s  “eye”  to  the  front  of  the 

object.  Front  has  one  optional  parameter:  a  distance.  If  the 
distance  is  positive,  the  viewer’s  eye  will  be  positioned  that 
much  further  than  the  default  distance  (700  mm)  from  the 
object.  If  the  distance  is  negative,  the  viewer’s  eye  will  be 
positioned  that  much  closer  to  the  object. 

Usage:  front  [distance] 

Example:  front  300 

Result:  The  viewer  is  now  looking  at  the  front  of 
the  object  from  a  distance  of  300  mm. 

fullcolor  This  command  allows  the  use  of  all  available  color 

information  (up  to  eight  bits  each  of  red,  green,  and  blue) 
instead  of  the  abbreviated  color  (four  bits  of  red  and  green, 
three  bits  of  blue)  normally  available.  Fullcolor  requires 
one  parameter:  the  base  file  name  of  the  color  file. 
INTEGRATE  automatically  adds  a  .color  or  .rgb  extension 
to  the  filename  you  specify.  The  data  path  is  also  added  to 
the  filename.  Fullcolor  has  two  optional  parameters:  min 
and  max.  If  min  and  max  are  specified,  the  color 
information  is  modified  as  follows:  for  each  color  axis  (r, 
g,  b)  all  values  below  min  are  set  to  0,  all  values  above 
max  are  set  to  255,  and  all  values  between  min  and  max  are 
rescaled  to  the  range  0  to  255.  For  example, 

FULLCOLOR  001_53P  0  128  tells  INTEGRATE  to  read 
all  color  information  from  file  001_53P.RGB  (or 
001_53P.COLOR)  and  rescale  all  values  from  0  to  128  to 
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the  range  0  to  255  (values  of  128  become  255,  values  of  64 
become  128,  etc.). 

Usage:  fullcolor  base_color_file_name  [min 

max] 

Example:  fullcolor  101_53p 

Result:  INTEGRATE  reads  all  color  information 

from  file  101_53p. 

This  command  makes  a  logarithmic  plot  of  the  Generalized 
Cross  Validation  equation  for  head  scan  data.  Generalized 
Cross  Validation  is  a  method  for  determining  the  best 
discrete  Gaussian  filter  scale  for  the  given  data.  The 
minimum  value  of  the  plot  is  a  conservative  estimate  for  the 
best  scale.  INTEGRATE  also  calculates  other  statistics 
(mean,  standard  deviation)  to  help  determine  the  appropriate 
scale. 


Usage:  gvc  [defaults]  or  [start  steps_decade 
total_steps] 

Example:  gvc 

Result:  INTEGRATE  makes  a  logarithmic  plot  of 
the  GCV  equation  for  the  active  object. 

This  command  reads  in  a  MOVIE.BYU  file  primarily  for 
display.  Gload  takes  one  argument:  the  name  of  the 
MOVIE.BYU  file  to  be  loaded. 

Usage:  gload  movie_file  [land_file] 

Example:  gload  body_scan.g 

Result:  INTEGRATE  loads  body_scan.g. 


gouraud 


gwrite 


help  [on/off] 


hide 


This  command  toggles  gouraud  shading  on  or  off  while  in 
RGB  mode  (see  the  rgb  command).  Gouraud  shading 
presents  a  smoother-looking  image. 

Usage:  toggle  command 
Example:  gouraud 

Result:  The  active  object  appears  with  gouraud 
shading  in  RGB  mode. 

This  command  writes  out  a  MOVIE.BYU  file.  Gwrite 
takes  one  argument,  the  name  of  the  MOVIE.BYU  file  to 
be  written  out. 

Usage:  gwrite  movie_file 
Example:  gwrite  body_scan.g 
Result:  INTEGRATE  writes  body_scan.g  to  the 
directory  from  which  INTEGRATE  was  launched. 

This  command  turns  the  list  of  available  commands  on  or 

off. 

Usage:  toggle  command 
Example:  help 

Result:  The  command  list  appears  or  disappears. 

This  command  temporarily  removes  an  object  from  the 
screen  without  removing  it  from  the  object  pool.  Hide  has 
one  optional  parameter:  the  number  of  the  object  to  hide.  If 
an  object  number  is  not  specified,  INTEGRATE  hides  the 
active  object. 

Usage:  hide  [object  number] 
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Example:  hide  5 

Result:  Object  5  disappears,  but  remains  in  the 
object  pool. 

histogram  This  command  creates  a  histogram  of  an  object.  The 

histogram  is  limited  to  ten  equally  spaced,  user  specified 
intervals.  INTEGRATE  stores  the  histogram  in  a  file 
called  histogram.dat.  INTEGRATE  then  activates  jot, 

SGI's  window-based,  full-screen  editor.  Jot  displays  the 
histogram  so  it  can  be  edited. 

Usage:  histogram  obj  interval 

Example:  histogram  1  30 

Result:  A  jot  window  appears  containing  the 

histogram  of  object  1  in  intervals  of  30  mm. 

intrphtd  This  command  enables  or  disables  interpolated  landmark 

mode.  Normally,  landmark  picking  selects  the  point  most 
representing  the  average  of  the  points  in  the  pick  region, 
but  with  intrplnd  mode  enabled,  the  actual  average  (when 
pickmode  average  is  selected)  is  set  as  the  landmark  point. 

Usage:  toggle  command 
Example:  intrplnd 

Result:  Interpolated  landmark  mode  is  enabled. 
Landmarks  will  be  positioned  at  the  average 
coordinates  of  the  points  within  the  pick  window 
(cursor  boundaries)  if  PICKMODE  AVERAGE  is 
active. 

jaw  This  command  only  works  when  the  active  object  is  a 

calipers  object.  It  moves  either  jaw  1  or  jaw  2  forward  or 
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backward  along  the  slide  bar.  Positive  movement  is  along 
the  direction  from  jaw  1  to  jaw  2.  Negative  movement  is 
along  the  direction  from  jaw  2  to  jaw  1 . 


jump 


land  [on/off] 


Usage:  jaw  [112]  <distance> 

Example:  jaw  2 -10 

Result:  If  jaw  2  is  more  than  10  mm  from  jaw  1, 
it  will  be  moved  10  mm  closer  to  jaw  1  along 
the  slide  bar.  If  it  is  less  than  10  mm  from  jaw 
1,  it  will  be  moved  to  adjoin  jaw  1. 

This  command  acts  as  a  “go  to”  command  in  a  batch  file. 
Jump  can  be  dependent  on  a  condition.  Conditions 
currently  supported  are:  always  (always  jump),  count 
(jump  a  specified  number  of  times),  and  smooth  (jump 
based  on  iterative  smoothing  criteria). 

Jump  needs  two  parameters:  the  condition  for  the  jump, 
and  the  comment  line  in  the  batch  file  to  go  to. 

Usage:  jump  condition  [comment  identifier] 
Example:  jump  count  5  *  start  here 
Result:  When  INTEGRATE  reaches  the  jump 
command  in  the  batch  file,  INTEGRATE  goes  to  the 
line  containing  “*  start  here”  and  begins  executing 
commands  at  that  point.  INTEGRATE  executes  the 
jump  five  times. 

This  command  displays  or  hides  the  landmark  points  for 
the  active  object  (if  landmarks  have  been  read  in  for  this 
object). 
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landlist  [on/off] 


left 


Uoad 


Usage:  toggle  command 
Example:  land 

Result:  The  active  object’s  landmarks  appear  or 
disappear. 

This  command  turns  the  list  of  standard  landmarks  on  or 
off.  If  an  Active  Object  is  selected  and  has  assigned 
landmarks,  the  "world"  coordinates  of  the  standard  and 
auxiliary  landmarks  for  the  Active  Object  will  also  be 
displayed  when  landlist  is  executed. 

Usage:  toggle  command 
Example:  landlist 

Result:  The  landmark  list  appears  or  disappears. 

This  command  moves  the  viewer’s  “eye”  to  the  left  side  of 
the  active  object. 

Usage:  left  [distance] 

Example:  left 

Result:  The  viewer  is  now  looking  at  the  left  side  of 
the  object. 

This  command  loads  a  landmark  file  for  the  active  object. 
Lload  needs  one  parameter:  the  name  of  the  landmark  file  to 
be  loaded. 

Usage:  lload  (landmark  file  name) 

Example:  lload  010_53p.lnd 

Result:  INTEGRATE  loads  the  010_53p.lnd 

landmark  file. 
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Iregister 


This  command  registers  (aligns)  an  object  to  another  object 
by  least-squares  fitting  of  corresponding  standard 
landmarks. 

Lregister  needs  two  parameters:  the  number  of  the  object  to 
be  registered  and  the  reference  object  number. 

Usage:  lregister  obj  ref_obj 
Example:  lregister  3  2 

Result:  INTEGRATE  registers  object  3  to  object  2, 
effectively  translating  and  rotating  object  3  into  the 
position  of  object  2. 

lwrite  This  command  writes  a  new  landmark  file.  Lwrite  has  one 

required  parameter  and  one  optional  parameter.  The  name 
of  the  landmark  file  to  be  written  is  required.  Rotate  (or 
just  r),  the  optional  parameter,  rotates  and  translates  the 
XYZ  coordinates  of  the  object. 

Usage:  lwrite  file_name  [rotate] 

Example:  lwrite  new_landmarks.lnd  r 
Result:  INTEGRATE  writes  the  landmark  file 
new_landmarks.lnd  to  the  directory  from  which 
INTEGRATE  was  launched,  rotating  and  translating 
the  object’s  XYZ  coordinates. 

man  This  command  displays  this  manual.  To  turn  the  manual 

off,  type  :q  and  PRESS  ENTER. 

Usage:  man 
Example:  man 

Result:  This  manual  appears  in  a  window  on  your 
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screen. 


median  This  command  replaces  a  point  with  the  median  value  of 

the  points  in  its  neighborhood.  This  helps  eliminate  data 
spikes..  Median  requires  one  parameter:  the  size  of  the 
neighborhood  window  for  median  computation. 

Usage:  median  window_size 
Example:  median  20 

Result:  For  every  point  in  the  active  object, 
INTEGRATE  computes  a  median  value  and  assigns 
that  value  to  the  point.  INTEGRATE  uses  the  20 
surrounding  points  for  the  calculation. 

merge  This  command  will  merge  the  points  from  two  objects  to 

become  a  third  object.  Merge  requires  2  parameters:  the 
numbers  of  the  objects  to  be  merged.  An  optional  third 
parameter  specifies  whether  to  use  the  maximum  radius, 
(max),  the  minimum  radius  (min),  or  the  average  radius 
(avg)  in  areas  where  the  objects  overlap. 

Usage:  merge  (objectl)  (object2)  [min,max,avg] 
Example:  merge  1  2  avg 

Result:  The  radial  values  from  object  1  and  object 
2  will  be  averaged  and  saved  in  the  next  available 
object  number. 

mload  This  command  loads  a  saved  displacement  matrix.  Mload 

requires  one  parameter:  the  name  of  the  saved  file. 

Usage:  mload  (matrix  file) 

Example:  mload  head_scan.mtx 
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modland 


move 


movevertex 


Result:  INTEGRATE  loads  the  head_scan.mtx 
displacement  matrix  and  transforms  the  active  object 
into  a  new  coordinate  system. 

This  command  positions  the  landmark  pointer  on  a 
specified  element  in  the  landmark  list.  When  picking 
points,  modland  allows  the  user  to  return  to  any  landmark 
in  the  list  and  reassign  coordinates  for  that  landmark. 
Modland’s  parameter  indicates  which  landmark  is  to  be 
picked  or  re-picked  next. 

Usage:  modland  (L#/Z#) 

Example:  modland  132 

Result:  The  landmark  pointer  moves  directly  to 
landmark  32  in  the  landmark  list. 

This  command  moves  the  active  object  along  the  X,  Y, 
and/or  Z  axes.  Move  needs  three  parameters:  the  distance 
in  millimeters  to  move  the  object  along  each  axis.  These 
.  distances  will  be  added  to  the  object’s  current  position. 

The  current  position  appears  in  the  blue  box  in  the  lower 
left  comer  of  the  screen. 

Usage:  move  (distance  along  X)  (distance  along  Y) 
(distance  along  Z) 

Example:  move  0  100  0 

Result:  The  active  object  moves  100  mm  up  the  Y 
axis. 

This  command  allows  the  movement  of  individual 
MOVIE.BYU  object  vertices.  It  requires  four  parameters: 
the  vertex  number  to  move  (see  pickmode  point),  and  the 
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movie_segment 


mwrite 

i 


.  X,  Y,  and  Z  distances  to  move  the  vertex.  This  is  useful 
for  hand-editing  specific  objects  when  the  object  is 
inaccurate  and  no  automated  method  is  available  for 
correcting  it. 

Usage:  move_vertex  (vertex  number)  (X  distance) 
(Y  distance)  (Z  distance) 

Example:  move_vertex  1 1234  1  2  3 

Result:  Vertex  11234  moves  1  mm  along  the  X  axis, 

2  mm  along  the  Y  axis,  and  3  mm  along  the  Z  axis. 

This  command  extracts  a  segment  of  a  mesh  object  by 
specifying  bounding  planes  in  the  directions  of  the  X,  Y, 
and  Z  axes.  A  complete  bounding  box  can  be  specified  by 
l(x/y/z)#,  which  provides  the  lower  boundary  on  the 
specified  axis  and  u(x/y/z)#,  which  provides  the  upper 
boundary  on  the  specified  axis.  All  six  possible  boundaries 
can  be  specified,  with  positive  or  negative  values,  as 
appropriate.  Note:  The  actual  screen  position  of  the  object 
(not  its  native  coordinate  system)  determines  which  points 
will  be  copied. 

Usage:  movie_segment  l(x/y/z)#  u(x/y/z)# 
Example:  movie_segment  lx-100  uxlOO  ly-100 
uylOO  lz-100  uzlOO 

Result:  INTEGRATE  copies  all  the  points  within  a 
200  mm  cube  around  the  origin  of  the  active  object 
and  stores  the  copied  points  in  a  new  object. 

This  command  writes  out  the  most  recent  displacement 
matrix  of  the  active  object  to  a  specified  file. 


91 


Usage:  mwrite  file 

Example:  mwrite  head_scan.mtx 

Result:  INTEGRATE  writes  the  active  object’s 

displacement  matrix  to  a  file  called  head_scan.mtx. 

INTEGRATE  stores  the  file  in  the  directory  from 

which  INTEGRATE  was  launched. 

nameland  This  command  assigns  a  name  to  an  auxiliary  (Z)  landmark. 

The  form  of  the  command  is:  nameland  Z# 

.  new_landmark_name.  New_landmark_name  must  not 
contain  blanks. 

Usage:  nameland  zlandmark#  new_name 
Example:  nameland  z2  helmet_landmarkl 
Result:  Auxiliary  landmark  Z2  is  renamed 
helmet_landmark  1 . 

negsub  This  command  performs  a  subtraction  on  two  objects  along 

each  radial  value.  Specify  a  reference  object  and  a  replace 
object  of  the  same  size  (that  is,  with  the  same  trim  values), 
and  INTEGRATE  subtracts  one  object  from  the  other.  The 
second  object  is  subtracted  from  the  first  object,  and  the 
results  less  than  zero  (negative  radial  values)  are  retained. 
INTEGRATE  stores  the  subtraction  results  in  the  replace 
(second)  object. 

Note:  For  best  results,  register  and  resample  the  objects 
before  executing  negsub. 

Usage:  negsub  reference_obj  replace_obj 
Example:  negsub  2  1 

Result:  INTEGRATE  subtracts  object  1  from  object 
2  and  stores  all  negative  values  in  object  1. 
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new  center 


new_order 


newland 


The  command  changes  the  center  point  of  an  object  to  the 
specified  coordinates  or  landmark. 

Usage:  newcenter  {  X  Y  Z  I  Ln  I  Zn} 

Example:  newcenter  z2 

Result:  The  new  center  of  rotation  of  the  active 

object  will  be  at  auxiliary  landmark  z2. 

This  command  reads  in  a  file  with  a  new  order  for 
landmark  picking  for  the  42  standard  landmarks  or  a  subset 
of  those  landmarks.  One  parameter  is  required:  the  file 
name  of  the  file  with  the  new  order  typed  in  it.  The  file 
should  have  landmark  numbers  (separated  by  a  space)  in 
the  order  that  the  landmarks  are  to  be  picked.  This 
command  requires  an  active  object  to  run. 

Usage:  neworder  filename 
Example:  neworder  special_landmarks 
Result:  INTEGRATE  reads  in  the  landmark  order 
file  called  special_landmarks. 

This  command  allows  manual  entry  of  a  landmark.  It 
operates  on  the  active  object  and  requires  4  parameters:  the 
destination  landmark  number  (L#  or  Z #)  and  the  X 
(right-left),  Y  (up-down),  and  Z  (near-far)  coordinates  in 
the  screen  coordinate  system.  The  user  can  include  a  name 
for  the  landmark,  also. 

Usage:  newland  (Z#/L#)  X  Y  Z  [new  landmark 
name] 

Example:  newland  zlO  20  20  20  helmet2 
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Result:  INTEGRATE  creates  a  new  auxiliary 
landmark,  Z10,  at  the  specified  coordinates  and 
names  it  helmet2. 

option  This  command  controls  preset  options  which  determine  the 

initial  state  of  an  object  after  it  is  loaded,  or  in  some  cases 
after  it  has  been  transformed.  Option  may  be  followed  by 
any  on/off  command.  For  example,  OPTION 
WIREFRAME  OFF  will  cause  all  future  objects  to  be 
loaded  without  immediately  displaying  the  wireframe  form. 
Similar  options  could  be  OPTION  SURFACE  ON  to  turn 
on  the  surface  form  of  an  object  as  soon  as  it  is  loaded,  or 
OPTION  FILL  ON  to  cause  voids  to  be  automatically  filled 
as  part  of  the  object  load  process,  and  after  any  significant 
manipulation  of  an  object. 

Usage:  option  (command)  on/off 

Example:  option  land  off 

Result:  When  you  load  an  object  and  its  landmark 

file,  the  object  appears  with  the  landmarks  hidden. 

ortho  This  command  toggles  between  the  normal  perspective 

view  and  an  orthographic  view  of  the  object  space.  This  is 
useful  for  removing  parallax  from  the  view  to  better 
interpret  relationships  between  points. 

Usage:  toggle  command 
Example:  ortho 

Result:  Objects  toggle  from  normal  view  to 
orthographic  view  or  from  orthographic  view  to 
normal  view. 
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pause 


This  command  supports  batch  processing  by  stopping  the 
execution  of  a  batch  file  until  the  operator  presses  a  key  to 
continue.  Note:  a  batch  file  can  also  be  paused  while  it  is 
running  by  pressing  any  key.  Do  not  use  Escape  (Esc)  to 
pause  a  batch  file.  Escape  terminates  batch  processing. 

Usage:  pause 
Example:  pause 

Result:  When  INTEGRATE  reaches  the  pause 
command  in  the  batch  file,  command  execution  stops 
until  the  operator  presses  a  key.  Note:  Do  not  press 
Escape  (Esc)  to  continue.  Escape  terminates  batch 
processing. 

pick  [on/off]  This  command  enables  or  disables  point  picking  mode. 

Usage:  toggle  command 
Example:  pick 

Result:  Point  picking  mode  is  enabled  or  disabled. 

pickmode  This  command  sets  the  point  picking  mode  to  perform 

specific  operations.  It  has  two  parameters:  a  mode  for 
selecting  a  specific  point  near  the  cursor,  and  a  mode  for 
using  the  point  to  automatically  perform  an  operation. 

Selection  options  are:  centroid,  closest,  or  median. 

Centroid  chooses  the  average  longitude  and  latitude  of  all 
the  points  which  were  detected  in  the  pick  region  (the 
points  indicated  by  the  cursor). 

Closest  chooses  the  longitude  and  latitude  of  the  point  in 
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the  pick  region  closest  to  your  eye  position. 

Median  chooses  the  longitude  of  the  longitudinal  median 
point  and  latitude  of  the  latitudinal  median  point  in  the 
pick  region. 

Usage:  pickmode  (centroid/closest/median) 
Example:  pickmode  closest 
Result:  INTEGRATE  chooses  the  longitude  and 
latitude  of  the  point  in  the  pick  region  closest  to  the 
viewer’s  “eye.” 

Operation  options  are:  con2p,  con3p,  cir2p,  cir3p,  mul2p, 
mul2a,  land,  auxland,  distance,  delpnt,  and  point. 

Con2p  causes  every  odd  point  to  be  the  start  point  of  a 
contour,  and  every  even  point  to  be  the  end  point  of  a 
contour,  with  the  center  of  the  object  defining  the  plane  of 
the  contour. 

Con3p  causes  every  group  of  three  points  to  define  a 
contour  plane,  with  the  contour  running  from  the  first 
point  to  the  second  point. 

Cir2p  and  cir3p  work  the  same  as  con2p  and  con3p,  except 
that  they  create  a  complete  circumference.  (Note  that 
contours  and  circumferences  do  not  work  properly  if  they 
encounter  a  boundary  of  the  object.) 

Mul2p  creates  multiple,  consecutive  two-point  contours  (the 
third  point  is  the  object  center),  with  the  second  point  of  a 
contour  becoming  the  first  point  of  the  next  contour. 
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planes  [on/off] 


Mul2a  creates  multiple,  consecutive  two-point  contours 
(the  third  point  is  the  Y-axis  at  mid-latitude),  with  the 
second  point  of  a  contour  becoming  the  first  point  of  the 
next  contour. 

Land  creates  a  new  standard  landmark  from  every  selected 
point. 

Auxland  creates  a  new  auxiliary  landmark  from  every 
selected  point. 

Distance  computes  the  straight-line  distance  from  the  first 
selected  point  to  each  point  selected  thereafter. 

Delpnt  deletes  the  selected  point. 

Point  reports  the  longitude,  latitude,  radius,  and  XYZ  value 
for  each  selected  point. 

Usage:  pickmode 

(con2p/con3p/cir2p/cir3p/mul2p/mul2a/land/auxland 

/distance/delpnt/point) 

Example:  pickmode  auxland 
Result:  INTEGRATE  creates  an  auxiliary  landmark 
at  the  point  the  user  picks  by  clicking  the  left  mouse 
button.  . 

This  command  turns  the  XY,  YZ,  and  XZ  reference  planes 
on  or  off. 

Usage:  toggle  command 
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Example:  planes 

Result:  The  reference  planes  appear  or  disappear. 


pload 


points  [on/off] 


pop 


This  command  loads  a  polygon  mesh  file  in  Stanford  .ply 
format.  After  loading,  the  object  is  identical  to  a 
movie.byu-format  mesh.  All  commands  that  work  with 
movie.byu  files  can  be  applied  to  the  loaded  object.  Pload 
requires  one  parameter:  the  name  of  the  .ply  file  to  be 
loaded. 


Usage:  pload  (file  name) 

Example:  pload  052.ply 

Result:  INTEGRATE  loads  the  polygon  mesh  file 
called  052.ply. 

This  command  enables  or  disables  a  display  of  the  scan 
data  for  the  active  object  as  individual  points. 

Usage:  toggle  command 
Example:  points 

Result:  INTEGRATE  turns  the  active  object’s  point 
display  on  or  off. 

This  command  redraws  the  INTEGRATE  window  over 
any  other  windows.  It  is  equivalent  to  the  window  menu 
POP  option. 

Usage:  pop 
Example:  pop 

Result:  Other  open  windows  on  the  screen  disappear 
behind  the  INTEGRATE  window. 
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possub 


This  command  performs  a  subtraction  on  two  objects  along 
each  radial  value.  Specify  a  reference  object  and  a  replace 
object  of  the  same  size  (that  is,  with  the  same  trim  values), 
and  INTEGRATE  subtracts  one  object  from  the  other.  The 
second  object  is  subtracted  from  the  first  object,  and  the 
results  greater  than  zero  (positive  radial  values)  are 
retained.  INTEGRATE  stores  the  subtraction  results  in  the 
replace  (second)  object. 

Note:  For  best  results,  register  and  resample  the  objects 
before  executing  possub. 

Usage:  possub  reference_obj  replace_obj 
Example:  possub  2  1 

Result:  INTEGRATE  subtracts  object  1  from  object 
2  and  stores  all  positive  values  in  object  1 . 

print  This  command  calls  up  the  snapshot  tool  which  saves  a 

section  of  the  screen  for  printing.  It  requires  no 
parameters. 

Usage:  print 
Example:  print 

Result:  The  snapshot  tool  appears.  Use  the  snapshot 
tool  to  capture  a  section  of  the  screen  for  printing. 

push  This  command  causes  all  other  windows  on  the  screen  to 

appear  on  top  of  the  INTEGRATE  window.  It  is 
equivalent  to  the  window  menu  PUSH  option. 

Usage:  push 
Example:  push 
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Result:  Open  windows  on  the  screen  appear  on  top  of 
the  INTEGRATE  window. 


pwrite 


readout 


recolor 


This  command  writes  out  a  polygon  mesh  object  in 
Stanford  .ply  format.  Pwrite  requires  one  parameter:  a 
name  for  the  file  to  be  written. 

Usage:  pwrite  (file  name) 

Example:  pwrite  101. ply 

Result:  INTEGRATE  writes  the  polygon  mesh  object 
to  a  file  called  101. ply  and  stores  the  file  in  the 
directory  from  which  INTEGRATE  was  launched. 

This  command  only  works  with  a  calipers  object  which  is 
the  active  object.  It  produces  the  measured  distance 
between  the  2  jaws  of  the  calipers.  A  parameter  indicates 
whether  the  measurement  is  for  the  outside  of  the  object 
(readout  outside)  (for  example,  measuring  head  breadth), 
or  the  inside  of  the  object  (readout  inside)  (for  example, 
measuring  the  distance  between  a  hand  and  the  body). 

Usage:  readout  [insideloutside] 

Example:  readout  outside 

Result:  The  distance  between  the  inner  surfaces 

of  the  jaws  is  reported  in  a  screen  message. 

This  command  rescales  the  color  file  values  for  the  active 
object  to  maximize  the  available  information.  Use  recolor 
to  make  an  object  lighter  or  darker  when  it’s  displayed  in 
full  color.  Recolor  requires  two  parameters:  the  minimum 
color  to  distinguish  from  black  and  the  maximum  color  to 
distinguish  from  white.  All  colors  between  the  min  and  the 
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max  will  be  rescaled  to  evenly  fill  the  color  space  between 
black  and  white.  Note  that  a  negative  minimum  is 
equivalent  to  adding  a  positive  offset  to  all  color  values. 

The  minimum  color  is  usually  set  to  zero.  If  the  user 
specifies  a  maximum  value  less  than  256,  the  object 
appears  lighter;  if  the  user  specifies  a  maximum  color 
greater  than  256,  the  object  appears  darker, 
lighter  <=  256  =>  darker 
Usage:  recolor  min  max 
Example:  recolor  0  198 
Result:  The  active  object  becomes  lighter  when 
displayed  in  full  color. 

refresh  This  command  supports  batch  processing  by  redrawing  the 

screen  in  the  middle  of  a  sequence  of  batch  operations. 
Normally  the  screen  is  not  redrawn  during  a  batch 
sequence. 

Usage:  refresh 
Example:  refresh 

Result:  When  INTEGRATE  reaches  the  refresh 
command  in  a  batch  file,  INTEGRATE  redraws  the 
objects  on  the  screen. 

remark  This  command  inserts  a  text  string  in  the  session  audit  trail. 

The  text  string  appears  in  the  INTEGRATE  session  record, 
stored  in  the  directory  from  which  INTEGRATE  was 
launched. 

Usage:  remark  (string) 

Example:  remark  starting  new  session 
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Result:  INTEGRATE  inserts  “starting  new  session” 
in  the  session  record. 

resample  This  command  copies  an  object  to  a  new  object  while 

re-establishing  an  orientation  to  the  standard  cylindrical 
grid  system  with  respect  to  the  center  of  the  screen  axis 
system. 

Resample  accepts  two  optional  parameters:  the  number  of 
the  object  to  resample,  and  the  number  of  interpolated 
points  to  include  in  the  sample.  If  an  object  number  is  not 
specified,  the  active  object  is  resampled. 

If  the  number  of  extra  samples  is  not  specified,  it  is  set  to  4, 
which  normally  gives  good  results.  The  available  range  is 
from  0  to  16.  The  number  of  samples  must  always  be  the 
second  parameter.  If  the  active  object  is  being  resampled, 
use  a  dash,  a  0,  or  the  number  of  the  active  object  for  the 
first  parameter. 

Resample  creates  a  new  object  in  the  first  available  slot  in 
the  object  pool. 

Usage:  resample  (obj)  (#  of  points) 

Example:  resample  -  16 

Result:  INTEGRATE  creates  a  copy  of  the  original 
object,  but  transforms  it  to  a  new  coordinate  system 
defined  by  the  object’s  orientation  to  the  center  of 
the  screen. 

rgb  This  command  toggles  between  color  map  mode  (limited  to 

2048  colors)  and  RGB  mode  (full  24-bit  color).  When  the 
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fullcolor  command  is  applied  to  an  object,  the  full  color  is 
available  for  viewing  the  surface  when  in  RGB  mode. 

Usage:  toggle  command 
Example:  rgb 

Result:  The  active  object  appears  in  full  color. 

right  This  command  moves  the  viewer’s  “eye”  to  the  right  side 

of  the  object.  Right  has  one  optional  parameter:  a  distance. 

If  the  distance  is  positive,  the  viewer’s  eye  will  be  that 
much  further  away  from  the  object  than  the  default 
distance.  If  the  distance  is  negative,  the  viewer’s  eye  will 
be  that  much  closer  to  the  object. 

Usage:  right  [distance] 

Example:  right 

Result:  The  viewer  sees  the  right  side  of  the  object. 

rotate  This  command  rotates  the  active  object  around  the  X,  Y, 

and/or  Z  axes.  Rotate  needs  three  parameters:  the  angle  to 
rotate  the  active  object  around  each  of  the  three  axes. 

These  angles  will  be  added  to  the  current  position.  The 
.  current  position  is  shown  in  the  blue  box  in  the  lower  left 
comer  of  the  screen. 

Usage:  rotate  (degrees  around  X)  (degrees  around 
Y)  (degrees  around  Z) 

Example:  rotate  0  30  20 
Result:  INTEGRATE  rotates  the  active  object  30 
degrees  around  the  Y  axis  (counterclockwise)  and  20 
degrees  around  the  Z  axis  (counterclockwise). 
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This  command  randomly  creates  void  patches  in  an  object. 
The  command  requires  both  the  object  and  a  copy  of  the 
object  to  operate.  After  execution,  the  copy  of  the  object 
will  contain  only  the  data  of  the  newly  created  voids.  It  is 
used  for  testing  various  object  editing  tools. 

Usage:  ruin  (object  to  ruin)  (copy  object) 
Example:  ruin  3  4 

Result:  INTEGRATE  creates  voids  in  object  3  and 
stores  the  voided  data  in  object  4. 

This  command  selects  which  object  is  the  active  object. 
Select  needs  one  parameter:  the  number  of  the  object  to  be 
selected.  Objects  can  also  be  selected  by  typing  in  just  the 
object  number. 

Usage:  select  (object  number) 

Example:  select  3 

Result:  Object  3  is  now  the  active  object. 

This  command  sets  a  parameter  in  the  ASPEC  for  an 
object.  Set  requires  two  parameters:  a  parameter  name 
and  a  new  parameter  value.  Useful  parameter  names  are 
RSHIFT,  NAME,  STUDY,  SCAN.TYPE,  VERSION, 
LTOFF,  LGOFF,  FILLED,  AND  SMOOTHED.  Other 
names  should  be  used  with  EXTREME  CAUTION.  The 
parameter  value  for  NAME,  STUDY,  or  SCAN_TYPE 
should  be  a  string  with  no  embedded  blanks.  The  value  for 
all  other  parameter  names  should  be  an  integer,  generally 
less  than  512. 


Usage:  set  (parameterl)  (parameter2) 


Example:  set  study  “traditional” 

Result:  The  information  contained  in  the  header 
under  STUDY_TYPE  will  be  changed  to  read 
traditional. 

shade  This  command  restores  or  updates  a  pseudo-lighting 

shaded  surface  to  an  object. 

Usage:  shade  [object  #] 

Example:  shade 

Result:  INTEGRATE  updates  the  shading  on  the 
active  object. 

show  This  command  displays  an  object  that  has  been  hidden. 

Show  has  one  optional  parameter:  the  number  of  the  object 
to  show.  If  an  object  number  is  not  specified,  INTEGRATE 
shows  the  active  object. 

Usage:  show  [object  #] 

Example:  show  3 

Result:  INTEGRATE  displays  object  3. 

shrink  This  command  is  used  to  reduce  the  radial  values  of  a  head 

scan  in  the  movie.byu  or  .ply  format  uniformly  and 
spherically.  An  example  use  of  shrink  is  to  approximate  the 
inner  surface  of  a  hollow  object  such  as  a  helmet. 

Usage:  shrink  (amount  in  mm) 

Example:  shrink  10 

Result:  The  head  scan  will  shrink  by  10  mm 
uniformly  and  spherically. 

side  This  command  moves  the  viewer’s  “eye”  to  the  left  side  of 
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the  object.  Side  has  one  optional  parameter:  a  distance.  If 
the  distance  is  positive,  the  viewer’s  “eye”  will  be  that  much 
further  away  from  the  object  than  the  default  distance.  If 
the  distance  is  negative,  the  viewer’s  “eye”  will  be  that 
much  closer  to  the  object. 

Usage:  side  [distance] 

Example:  side 

Result:  The  viewer  sees  the  left  side  of  the  object. 

This  command  skips  over  a  landmark  slot  when  picking 
landmarks.  Skip  has  one  optional  parameter:  the  number  of 
landmark  slots  to  skip.  If  a  skip  number  is  not  specified, 
INTEGRATE  skips  one  slot.  If  a  negative  number  is 
specified,  INTEGRATE  skips  backward  in  the  landmark 
list. 


Usage:  skip  [value] 
example:  skip  -1 

Result:  INTEGRATE  skips  backward  one  slot  in  the 
landmark  list. 

This  command  supports  batch  processing  by  forcing  the 
batch  process  to  stop  for  a  given  number  of  seconds,  in 
order  to  give  the  operator  time  to  observe  the  state  of  an 
image  before  processing  continues.  Sleep  accepts  one 
parameter:  the  number  of  seconds  to  wait  before 
continuing.  If  the  number  of  seconds  is  not  specified,  the 
batch  file  pauses  for  one  second. 

Usage:  sleep  [value] 

Example:  sleep  10 


Result:  INTEGRATE  pauses  for  10  seconds  when  it 
reaches  the  sleep  command  in  the  batch  file. 

smooth  [on/off]  This  command  enables/disables  automatic  smoothing  for  an 

object  after  a  command,  such  as  cload  or  resample,  which 
disturbs  the  smoothness  of  the  data.  To  execute  smoothing 
for  the  active  object,  use  do  smooth. 

Usage:  toggle  command 
Example:  smooth 

Result:  Automatic  smoothing  is  turned  on  or  off. 

split  This  command  computes  a  new  landmark  at  the  mid-point 

between  two  other  landmarks.  It  operates  on  the  active 
object  and  requires  three  parameters:  the  destination 
landmark  number  (L#  or  Z#)  and  the  two  defining 
landmarks  (L#  or  Z#).  There  are  two  optional  parameters 
for  this  command,  weight  1  and  weight2,  which  cause  the 
new  landmark  to  be  positioned  proportionally  between  the 
two  defining  landmarks.  The  weight  function  might  be 
used  for  determining  a  combined  Center  of  Gravity  from 
the  CG's  of  two  objects  of  different  weights,  such  as  a 
human  head  and  a  helmet  system. 

Usage:  split  ([Z/L]destination  landmark  #)  ([Z/L] 
first  landmark  #)  ([Z/L]  second  landmark  #)  [wtl] 
[wt2] 

Example:  split  z20  zl  z2  .5  2 
Result:  INTEGRATE  creates  a  new  auxiliary 
landmark,  z20,  between  landmarks  zl  and  z2.  The 
weights,  .5  for  zl  and  2  for  z2,  tell  INTEGRATE  to 
position  z20  80%  of  the  way  toward  z2. 
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store  [on/off] 


subject  [on/off] 


INTEGRATE  uses  the  following  equation  to 
determine  the  new  landmark’s  location: 

(weighti*coordinateS])+(weight2»coordinates2) 

weight!  +  weight2 

This  command  enables  or  disables  storage  of  data  from 
various  measurement  commands  to  a  disk  file.  When  store 
is  enabled,  results  of  VOLUME,  SURFACE_AREA, 
DISTANCE,  and  PICKMODE  DISTANCE  point  picks  are 
stored  to  "measures.txt"  with  appropriate  labels. 

Usage:  toggle  command 
Example:  store 

Result:  Data  from  measurement  commands  are  stored 
in  a  file  called  measures.txt  in  the  directory  from 
which  INTEGRATE  was  launched. 

This  command  turns  all  display  modes  for  the  active  object 
on  or  off.  Subject  on  is  the  same  as  show  and  subject  off 
is  the  same  as  hide.  Subject  by  itself  works  like  any  other 
on/off  command;  it  toggles  between  on  and  off. 

Usage:  toggle  command 
Example:  subject 

Result:  INTEGRATE  hides  or  shows  the  active 
object. 


super 


This  command  allows  several  objects  to  be  grouped  into  a 
“super  object”  so  all  the  objects  can  be  moved  or  changed 


together.  In  keeping  with  the  concept  of  a  "super-object,” 
this  is  a  "super-command"  with  six  command  modifiers: 
MAKE,  ADD,  RELEASE,  DELETE,  LINK,  and  UNLINK. 
MAKE  creates  a  new  super-object,  ADD  adds  objects  to  a 
super-object,  RELEASE  removes  one  or  more  objects  from  a 
super-object,  DELETE  deletes  the  super-object,  LINK 
attaches  a  sub-object  and  applies  an  offset  that  causes  the 
sub-object  to  rotate  around  the  same  rotation  point  as  the 
super-object,  and  UNLINK  removes  the  offset  and  detaches 
the  sub-object.  Note  that  the  DELETE  command  (by  itself) 
applied  to  a  super-object  is  identical  to  the  SUPER  DELETE 
command. 

Usage: 

SUPER  MAKE  sub-objl ...  sub-obj# 

SUPER  ADD  super-obj  sub-objl ...  sub-obj# 

SUPER  RELEASE  super-obj  sub-objl ...  sub-obj# 
SUPER  DELETE  super-obj 
SUPER  LINK  super-obj  sub-obj 
SUPER  UNLINK  super-obj  sub-obj 
Example:  supermake2  34 

Result:  INTEGRATE  groups  objects  2,  3,  and  4  into  a 
super  object. 

surfjreg  This  command  attempts  to  improve  a  rough  registration 

between  2  similar  objects  by  iteratively  computing  distances 
and  angles  bewteen  the  2  surfaces,  then  correcting  for  the 
observed  errors.  Often  a  rough  alignment  can  be 
accomplished  using  3  or  more  common  landmarks  and  using 
lregister  or  zregister  to  register  one  object  with  another. 

This  command  accepts  six  parameters: 
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.  test_object  -  object  to  be  adjusted  based  on  surface  matching 
ref_object  -  oject  to  be  matched  against 
thres  -  maximum  distance  between  matched  points  to  limit 
accidental  matching  with  points  on  the  far  side  of  an  object. 
Should  be  less  than  half  the  minimum  diameter  of  the  smallest 
object,  but  more  than  the  maximum  distance  between  the  two 
surfaces  in  the  matching  region.  The  default  for  thresh  is  50.0 
mm. 

nTries  -  the  number  of  trials  between  asking  the  operator  for 
input.  After  nTries  trials,  the  operator  is  given  the  choice  of: 
stopping  the  registration  (N),  continuing  the  registration  (Y), 
or  adjusting  the  number  of  probes  being  used  (1,  2,  4,  8,  0). 
The  number  of  probes  is  the  number  specified  by  nProbes, 
divided  by  a  speedup  factor  of  1,  2,  4,  8,  or  16.  The  speedup 
•  factor  makes  each  loop  correspondingly  faster,  but  may  reduce 
the  accuracy  of  the  match,  so  the  operator  is  given  control  to 
balance  the  time  spent  vs.  the  accuracy.  The  default  for 
nTries  is  50. 

nProbes  -  the  maximum  number  of  probes  in  each  trial.  The 
actual  number  of  probes  may  be  less  than  nProbes  if  a  speedup 
factor  has  been  specified.  The  probes  are  randomly  selected 
from  the  entire  set  of  points  in  the  test  object.  For  each  probe 
point,  a  corresponding  point  on  the  reference  object  is 
determined  by  finding  the  point  where  the  normal  to  the  probe 
point  intersects  the  reference  object.  The  matched  points  are 
then  used  in  the  same  alignment  algorithm  used  by  lregister 
and  zregister.  The  default  for  nProbes  is  1/10  of  the  points  in 
the  test  object. 

rotateAxis  -  sometimes  it  is  desirable  to  limit  the  freedom  of 
the  rotations  and  translations  which  can  take  place  in  the 
matching  process.  For  instance,  objects  may  be  known  to  be 
positioned  at  the  same  height  with  the  same  vertical  axis,  so 
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surface  [on/off] 


surface_area 


limiting  the  displacements  to  horizontal  translations  and 
rotations  might  be  expected  to  produce  a  more-exact  result. 
By  specifying  the  vertical  axis  (usually  Y  in  INTEGRATE)  as 
the  rotateAxis,  extraneous  displacements  can  be  avoided. 
The  default  is  unconstrained  rotations  and  translations. 

Usage:  surf_reg  test_obj  ref_obj  [thres  [nTries  [nProbes 
[rotateAxis]]]] 

Example:  surf_reg  5  4  25.0  15  500 
Result:  Object  5  will  be  surface_registered  with  object  4. 
Points  in  object  4  that  are  more  than  25  mm  away  from  a 
test  point  in  object  1  will  be  disqualified  for  surface 
point  matching.  Every  15  loops  the  command  will 
pause  for  operator  action.  If  object  5  has  more  than  500 
points,  the  command  will  choose  500  randomly-selected 
points  for  surface  matching.  RotateAxis  is  not  specified, 
so  rotation  and  translation  are  not  constrained. 

This  command  enables  or  disables  a  display  of  the  scan  data 
for  the  active  object  as  shaded  surface  polygons. 

Usage:  toggle  command 
Example:  surface 

Result:  INTEGRATE  turns  the  surface  display  on  or 
off  for  the  active  object. 

This  command  computes  the  displayed  surface  area  of  the 
active  object. 

Usage:  surface_area 
Example:  surface_area 

Result:  INTEGRATE  computes  the  surface  area  of  the 
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active  object  and  displays  the  result  in  the  lower  left 
comer  of  the  screen. 

tape  This  command  converts  a  surface  contour/circumference  into 

a  tape-measure-equivalent  by  eliminating  any  concave  curves 
in  the  surface.  The  resulting  distance,  of  the  modified  contour 
should  then  approximate  the  distance  measured  with  a  tape 
measure. 

This  command  has  two  parameters:  the  contour  to  be 
modified  and  has  an  optional  parameter  which  indicates 
whether  the  tape  measure  completely  wraps  around  the 
object.  This  command  might  not  work  well  for  very  complex 
curves,  since  it  uses  the  center  of  mass  of  the  contour  points 
as  a  reference  point  If  the  center  of  mass  falls  outside  the 
curve,  results  are  unpredictable. 

Usage:  tape  (contour#)  [wrap/nowrap] 

Example:  tape  2 

Result:  The  contour  is  converted  into  a  completely 
convex  curve.  Since  the  wrap  parameter  is  not 
specified,  the  end  points  are  excluded  from  the 
removal  algorithm. 

text  This  command  will  print  a  text  string  on  the  screen. 

The  parameters  are  x  coordinate,  y  coordinate,  size,  and  the 
text  string. 

Usage:  text  xcoord  ycoord  size  string 
Example:  text  10  300  4  my  text 
Result:  The  text  string  “my  text”  will  show  up  on 
the  lower  left  hand  comer  of  the  screen. 
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thin  This  command  sets  the  frequency  of  longitude  and  latitude 

lines  to  be  shown  on  the  active  object.  Thinning  an  object 
speeds  up  some  INTEGRATE  functions. 

Thin  needs  two  parameters:  the  longitude  thin  factor  and  the 
latitude  thin  factor.  For  example,  for  a  thin  factor  of  2, 
INTEGRATE  displays  every  second  data  point;  for  a  thin 
factor  of  3,  INTEGRATE  displays  every  third  data  point, 
and  so  on. 

Usage:  thin  value  value 
Example:  thin  2  2 

Result:  INTEGRATE  displays  only  every  second 
data  point  along  each  longitude  and  latitude. 


Object 
before 
thinning 

Figure  18:  Thinning  an  object. 


Object  after 
executing 
thin  2  2 


threshold  This  command  performs  a  threshold  operation  on  an  object. 

The  object  and  threshold  values  are  specified  by  the  user. 
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The  qualifiers  eq  (equal),  ne  (not  equal),  It  (less  than),  le 
(less  than  or  equal),  gt  (greater  than),  ge  (greater  than  or 
equal)  refer  to  the  values  to  be  zeroed.  For  example, 
“threshold  2  It  55”  means  all  points  in  object  2  below  the  55 
threshold  should  be  set  to  zero. 

Usage:  threshold  (object  #)  (eq/ne/lt/le/gt/ge)  (value) 
Example:  threshold  4  It  2 
Result:  INTEGRATE  eliminates  all  radial  values 
less  than  2  mm  on  object  4. 

This  command  moves  the  viewer’s  “eye”  to  the  top  of  the 
object. 

Top  has  one  optional  parameter:  a  distance.  If  the  distance  is 
positive,  the  viewer’s  eye  will  be  positioned  that  much 
further  from  the  object.  If  the  distance  is  negative,  the 
viewer’s  eye  will  be  positioned  that  much  closer  to  the 
object. 

Usage:  top  [distance] 

Example:  top  200 

Result:  The  viewer  now  sees  the  top  of  the  active 
object,  200  mm  further  away  from  the  object  than 
before. 

This  command  converts  snap.rgb  files  from  snapshot 
format  to  postscript  format.  It  requires  one  parameter:  the 
name  of  the  file  where  the  postscript  commands  will  be 
stored. 


Usage:  tops  postscript_file 


toupee 


transparent  [on/off] 


Example:  tops  figure.ps 

Result:  The  snapshot  file  is  converted  to  postscript 
format  and  stored  in  figure.ps  in  the  directory  from 
which  INTEGRATE  was  launched.  The  figure.ps  file 
can  be  printed  on  any  postscript  printer. 

This  command  fills  in  the  top  of  the  head  of  the  active 
object.  Note  that  this  command  works  best  when  the  object 
is  positioned  so  that  the  (estimated!)  highest  point  on  the 
head  is  centered  on  the  Y  axis.  This  command  needs  two 
parameters:  the  lowest  latitude  for  the  toupee,  and  the 
highest  latitude  for  the  toupee.  Check  the  object 
coordinates  in  the  blue  box  on  the  lower  left  for  the 
coordinates  to  use  for  the  toupee.  Note  that  the  low  latitude 
must  be  within  the  current  trim  area. 

Usage:  toupee  (bottom  of  toupee  latitude)  (top  of 
toupee  latitude) 

Example:  toupee  196  203 

Result:  INTEGRATE  places  a  cap  or  “toupee”  on  the 
void  on  top  of  the  active  object. 

This  command  makes  the  surface  display  for  an  object 
partially  transparent,  allowing  visualization  of  the  detail  of 
the  grid  or  of  inner  objects.  Because  all  objects  use  the 
same  transparency  mask,  a  transparent  object  will  not  be 
visible  inside  another  transparent  object. 

Usage:  toggle  command 
Example:  transparent 
Result:  The  active  object  becomes 
transparent. 
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trim 


This  command  modifies  the  starting  and  ending  longitude 
and  latitude  so  that  only  the  necessary  part  of  the  active 
object  will  be  displayed.  Trim  needs  four  parameters 
which  will  change  the  starting  longitude,  ending  longitude, 
starting  latitude,  and  ending  latitude.  These  parameters  will 
be  added  to  the  current  values.  To  reduce  the  ending 
longitude  and  latitude,  use  a  negative  number.  The  current 
starting  and  ending  longitude  and  latitude  are  displayed  in 
the  blue  box  in  the  lower  left  comer  of  the  screen. 

Usage:  trim  leftjong  rightjong  lower_lat 
upperjat 

Example:  trim  30 -100  50 -50 

Result:  INTEGRATE  trims  the  active  object. 


Figure  19:  Trimming  noise  from  the  top  of  an  object:  before  trimming 
(the  object  on  the  left)  and  after  trimming  (the  object  on  the  right). 


volume 


This  command  computes  the  volume  between  the  surface 
of  the  active  object  and  the  center  of  the  object.  This 
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command  also  generates  the  coordinates  of  the  center  of 
volume. 


Usage:  volume 
Example:  volume 

Result:  INTEGRATE  computes  the  volume  and 
center  of  volume  of  the  active  object  and  displays  the 
result  in  the  lower  left  comer  of  the  screen. 

walls  This  command  sets  the  clipping  planes.  The  clipping  planes 

control  the  size  of  the  viewing  area. 

Walls  needs  two  parameters:  near  or  far. 

near  -  points  closer  to  the  eye  than  the  near  value 
will  not  be  displayed  (initial  value  100). 
far  -  points  farther  from  the  eye  than  far  will  not 
be  displayed  (initial  value  1400). 

Walls  also  accepts  two  other  parameters:  full  and  half. 

"Walls  full"  automatically  sets  the  near  wall  to  100  and  the 
far  wall  to  twice  the  distance  of  the  viewpoint  from  the 
origin  of  the  grid.  "Walls  half'  automatically  sets  the  near 
wall  to  100  and  the  far  wall  to  the  distance  of  the  viewpoint 
from  the  origin  of  the  grid,  eliminating  from  view  the  back 
half  of  an  object  centered  on  the  origin.  If  the  viewpoint  is 
moved  using  eye,  top,  front,  or  side,  the  walls  may  need  to 
be  adjusted  to  prevent  clipping  of  the  object. 

Usage:  walls  near/far 
Example:  walls  698  702 

Result:  INTEGRATE  limits  the  viewing  area  to  the 
space  between  698  and  702. 


117 


Figure  20:  With  walls  set  to  698  702,  only  a  cross 
section  of  the  object  appears. 


white  This  command  sets  the  screen  background  color  to  white. 

Landmark  and  object  points  will  change  colors  so  that  they 
will  show  up  against  the  white  background.  Typically 
white  is  used  to  prepare  a  screen  for  printing  to  reduce  the 
total  number  of  pixels  which  must  be  transferred  to  the 
printer. 


Usage:  white 
Example:  white 

Result:  The  screen  background  turns  white. 
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wireframe  [on/off] 


wload 


wwrite 


xload 


This  command  enables  or  disables  wireframe  display  of  the 
active  object. 

Usage:  toggle  command 
Example:  wireframe 

Result:  Wireframe  display  of  the  active  object  turns 
on  or  off. 

This  command  reads  in  a  polygon  mesh  file  in  wavefront 
.obj  format.  After  loading,  the  object  is  identical  to  a 
movie.byu-format  mesh.  All  commands  that  work  with 
movie.byu  files  can  be  applied  to  the  loaded  object.  Wload 
requires  one  parameter:  the  name  of  the  .obj  file  to  be 
loaded. 


Usage:  toggle  command 
Example:  wireframe 

Result:  Wireframe  display  of  the  active  object  turns 
on  or  off. 

This  command  writes  out  a  polygon  mesh  file  in  wavefront 
.obj  format.  Wwrite  requires  one  parameter:  the  name  of 
the  file  to  be  written. 

Usage:  wwrite  (file  name) 

Example:  wwrite  025 .obj 

Result:  INTEGRATE  writes  the  mesh  object  to  a  file 
called  025  .obj  and  stores  the  file  in  the  directory 
from  which  INTEGRATE  was  launched. 

This  command  reads  in  data  stored  in  XYZ  coordinate 
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format  (see  xwrite). 


Usage:  xload  file 

Example:  xload  head_scan.xyz 

Result:  INTEGRATE  reads  in  the  file  head_scan.xyz. 

xwrite  This  command  writes  scan  data  XYZ  coordinates  to  an 

ASCII  (text)  file.  If  the  -g  (grid)  option  is  specified, 
longitude,  latitude,  and  radius  are  also  written  to  the  file. 

If  the  -a  (all)  option  is  specified,  void  points  are  written  to 
the  file;  otherwise,  only  non- void  (radius  >  0.0)  points  are 
written.  If  the  -w  (waterline)  option  is  specified,  the  data 
points  are  written  in  latitude-major  order  (all  points  at  the 
same  latitude  grouped  together)  instead  of  longitude-major 
order.  If  no  options  are  specified,  the  filename  to  be 
written  is  the  first  parameter.  If  options  are  specified,  the 
filename  to  be  written  is  the  second  parameter. 

Usage:  xwrite  [-agw]  file 
Example:  xwrite  -a  ascii52.2.xyzl 
Result:  INTEGRATE  writes  data,  including  void 
points,  to  a  file  called  ascii52.2.xyzl,  stored  in  the 
directory  from  which  INTEGRATE  was  launched. 

zload  This  command  reads  in  previously  stored  contour  data  (see 

zwrite).  Zload  requires  one  parameter:  the  name  of  the 
contour  file  to  be  read  in.  Note:  if  a  contour  file  exceeds 
the  maximum  allowed  size  of  a  single  contour  line,  the 
contour  will  be  broken  into  separate  contour  lines  as 
required. 

Usage:  zload  file 
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Example:  zload  contours 

Result:  INTEGRATE  reads  in  the  contour  data  file 

called  contours. 

zregister  This  command  registers  an  object  to  another  object  by 

least-squares  fitting  of  corresponding  auxiliary  landmarks. 
Zregister  needs  two  parameters:  the  number  of  the  object 
to  be  registered  and  the  reference  object  number. 

Usage:  zregister  obj  refobj 
Example:  zregister  2  1 

Result:  INTEGRATE  uses  the  auxiliary  landmarks 
to  align  object  2  on  object  1 . 

zwrite  This  command  writes  out  the  points  which  make  up  a 

contour  or  circumference  line.  The  first  parameter  to  zwrite 
is  the  name  of  the  file  to  be  written.  All  following 
parameters  are  contour  numbers  to  be  written. 

Usage:  zwrite  file  contourl...  contour#  [rotate] 
Example:  zwrite  contour_file  3  4  5  r 
Result:  INTEGRATE  writes  contours  3, 4,  and  5  to  a 
file  called  contour_file  in  the  directory  from  which 
INTEGRATE  was  launched. 


121 


5.0  INTEGRATE’S  AUDIT  TRAIL  FUNCTION 


INTEGRATE’ s  Audit  Trail  maintains  a  record  of  all  user  commands  entered  during  an  INTEGRATE 
session.  The  Audit  Trail  file  allows  the  user  to: 

•  analyze  an  INTEGRATE  session  to  discover  the  cause  of  unsatisfactory  results, 

•  record  the  history  of  a  modified  dataset  so  future  users  can  evaluate  the  validity  of  the  final 
data, 

•  create  a  batch  file  that  will  automatically  reproduce  the  results  of  the  session. 

INTEGRATE  stores  the  commands  in  a  file  called  AUDITFTLE.xxxx,  where  xxxx  is  the  first  four 
characters  in  the  name  of  the  INTEGRATE  system  host.  For  example,  a  system  whose  host  name  is 
falcon  will  produce  audit  trail  files  called  AUDITFILE.falc.  The  audit  trail  files  are  stored  in  the 
directory  from  which  INTEGRATE  was  launched. 

INTEGRATE  stores  all  commands  executed  during  the  INTEGRATE  session  except  actions  initiated 
during  point  picking.  For  example,  if  the  user  deleted  points  from  a  dataset  with  pickmode  delall,  the 
deletion  of  every  point  in  the  dataset  would  not  appear  in  the  audit  file.  If  all  the  pickmode  actions  were 
included,  it  would  be  difficult  to  find  more  useful  information  in  the  file. 

IAUDIT  is  a  program  that  allows  the  user  to  view  and  manipulate  INTEGRATE’s  audit  trail  files. 
Instructions  for  using  IAUDIT  appear  below. 

5.1  Using  IAUDIT 

Follow  these  steps  to  view  and  manipulate  audit  trail  files: 

1 .  Change  directory  (cd)  to  the  directory  from  which  INTEGRATE  was  launched  for  the  relevant 
session. 

2.  Type  iaudit  and  press  Enter. 

3.  When  the  list  of  audit  trail  files  appears,  determine  which  audit  file  contains  the  relevant 
session  record.  The  sessions  are  numbered  and  are  listed  by  date,  time,  and  user  name.  A  few 
lines  of  the  session  list  might  look  like  this: 

42:  ***  Integrate  Session  3/15/1996  8:55:32  chris 
43:  ***  Integrate  Session  3/18/1996  10:15:12  mark 
44:  ***  Integrate  Session  3/19/1996  14:39:10  josephine 
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4.  Type  an  IAUDIT  command  that  contains  the  option  for  carrying  out  the  required  action.  The 
table  below  defines  the  IAUDIT  options: 


iaudit  (with  no  options) 

Lists  the  INTEGRATE  sessions  by  date  and  time. 

-a 

Lists  every  command  that  was  executed  in  the  session  or  sessions. 

-b 

Creates  a  batch  file  that  includes  all  “first  level”  commands.  Commands  from 

subsidiary  batch  files  are  not  included,  though  the  @(batch  file  name) 

commands  that  launch  batch  files  are  included. 

-d 

Deletes  sessions  from  the  session  list. 

-t 

Creates  a  batch  file  that  does  not  include  any  batch  file  commands,  not  even 

the  @  (batch  file  name)  commands  that  launch  batch  files.  It  does  include  all 

other  comands,  whether  typed  in  or  read  from  a  file. 

5.  To  list  all  the  commands  in  sessions  5  through  10,  type  a  command  that  looks  like  this: 

iaudit  -a  5  10 

6.  To  create  a  batch  file  from  the  commands  in  sessions  24,  type  a  command  that  looks  like  this: 

iaudit  -b  24>newbatch 

where  “newbatch”  is  the  name  of  the  batch  file  to  be  created. 

7.  To  delete  sessions  10  through  20  from  the  session  list,  type  a  command  that  looks  like  this: 

iaudit  -d  10  20 

8.  To  create  a  batch  file  from  the  commands  in  session  12,  merging  any  secondary  batch  file 
commands,  type  a  command  that  looks  like  this: 

iaudit  -t  12>newbatch 

where  “newbatch  is  the  name  of  the  batch  file  to  be  created. 

9.  Use  a  text  editor  to  edit  the  batch  files.  Some  commands  may  need  to  be  deleted,  and  some 
commands  may  need  to  be  combined  into  one  command. 
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APPENDIX  A 

TUTORIALS:  IMAGE  DATA  AND  SCRIPT  FILES 
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FILES  NEEDED  FOR  TUTORIAL  1 


SCRIPT  FILE  IMAGE  FILE(S) 


COLOR  FILE(S) 


tutorial_l  010_53p 


010_53p.rgb 


SCRIPT  FILE  FOR  TUTORIALS 

cload  010_53p 

lload  010_53p.lnd 

rotate  0  75 

right 

back 

left 

top 

bottom 
front 
move  50 
move  0  50 
right 

move  0  0  50 
move  -50  -50  -50 
front 

trim  0  0  0  -55 
trim  0  0  55 
copy  1  2 
ruin  I  2 
hide  2 
1 

do  fill 

toupee  200  205 

axes 

boxes 

boxes 

alt_land 

landlist 

landlist 

help 

help 

fkeys 

land 

land 

wireframe 

surface 

fullcolor  010_53p 
rgb 

volume 

surface_area 


LANDMARK  FILE(S) 
010_53p.lnd 
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FILES  NEEDED  FOR  TUTORIAL_2 

SCRIPT  FILE  IMAGE  FILE(S)  LANDMARK  FILE(S) 

tutorial_2  010_53p  010_53p.lnd 

010_53ph  0I0_53ph.lnd 

53psize5  53psize5.1nd 


SCRIPT  FILE  FOR  TUTORIAL_2 

cload  010_53p 
rotate  0  75 
right 

trim  0  0  0  -55 
trim  0  0  55 
toupee  200  205 
do  fill 

lload  010_53p.lnd 
cload  010_53ph 
trim  0  0  0  -50 
trimOO  45 
lload  010_53ph.lnd 
Register  2  1 
right 

walls  695  699 
walls  full 
front 

cload  53psize5 
lload  53psize5.1nd 
zregister  3  2 
right 

walls  695  699 
hide  2 
walls  full 
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FILES  NEEDED  FOR  TUTORIAL^ 
SCRIPT  FILE  IMAGE  FILE(S)  COLOR  FILE(S) 

tutorial_3  010_53p  010_53p.rgb 


SCRIPT  FILE  FOR  TUTORIAL^ 

cload  010_53p 
trim  0  00  -50 
trim  0  0  58 
do  fill 

toupee  205  207 

wireframe 

surface 

fiillcolor  010_53p 
rgb 

pick  on 
pickmode  land 
right 

rotate  0  75 

***begin  point  picking 


LANDMARK  FILE(S) 
010_53p.lnd 
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FILES  NEEDED  FOR  TUTORIAL_4 


SCRIPT  FILE 

IMAGE  FILE(S) 

LANDMARK  FILE(S) 

tutorial_4 

53psize5 

53psize5.1nd 

100_53ph 

100_53ph.lnd 

100_53p 

100_53p.lnd 

101_53ph 

101_53ph.lnd 

101_53p 

101_53p.lnd 

102_53ph 

102_53ph.lnd 

102_53p 

102_53p.lnd 

104_53ph 

104_53ph.lnd 

104_53p 

104_53p.lnd 

105_53ph 

105_53ph.lnd 

105_53p 

105_53p.lnd 

SCRIPT  FILE  FOR  TUTORIAL_4 

cload  53psize5 
lload  53psize5.1nd 
align  xz  zl  z5  z3  z3 
cload  100_53ph 
lload  100_53ph.lnd 
zregister  2  1 
cload  100_53p 
lload  100_53p.lnd 
lregister  3  2 
1 

copy  land  11  3  134 
copy  land  12  3  138 
cload  101_53ph 
lload  101_53ph.lnd 
zregister  4  1 
cload  101_53p 
lload  101_53p.lnd 
lregister  5  4 
1 

copyland  13  5  134 
copyland  14  5  138 
cload  102_53ph 
lload  102_53ph.lnd 
zregister  6  1 
cload  102_53p 
lload  102_53p.lnd 
zregister  7  6 
1 

copyland  15  7  134 
copyland  16  7  138 
cload  104_53ph 
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lload  104_53ph.lnd 
zregister  8  1 
cload  104_53p 
lload  104_53p.lnd 
lregister  9  8 
1 

copyland  17  9  134 
copyland  18  9 138 
cload  105_53ph 
lload  105_53ph.lnd 
zregister  10  1 
cload  105_53p 
lload  105_53p.lnd 
lregister  11  10 
1 

copyland  19  11 134 

copyland  110  1 1 138 

hide  2 

hide  3 

hide  4 

hide  5 

hide  6 

hide  7 

hide  8 

hide  9 

hide  10 

hide  11 

right 

back 

left 

front 
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FILES  NEEDED  FOR 

TUTORIAL_5 

SCRIPT  FILE 

IMAGE  FILE(S) 

COLOR  FILE(S) 

LANDMARK  FELE(S) 

tutorial_5 

face 

face.rgb 

mask 

mask.rgb 

SCRIPT  FILE  FOR  TUTORIAL_5 


cload  face 
move  0  200 
cload  mask 
move  0  200 
possub  1  2 
threshold  2  ge  1 
and  1  2 
cload  mask 
move  0  200 
negsub  1  3 
threshold  2  ge  1 
and  1  3 
cload  mask 
move  0  200 
possub  1  4 
•  threshold  4  It  1 
and  1  4 
cload  mask 
move  0  200 
negsub  1  5 
threshold  5  It  1 
and  1  5 
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FILES  NEEDED  FOR  TUTORIAL_6 
SCRIPT  FILE  IMAGE  FILE(S)  LANDMARK  FILE(S) 


tutorial_6 


head.g 

pasgt.g 

head.pasgt.cdd 


head.lnd 

pasgt.lnd 

head.pasgt.lnd 


MATRIX  FILE(S) 


SCRIPT  FILE  FOR  TUTORIAL_6 

option  wireframe  off 
option  points  on 
eye  0  0  1200 
gload  head.g 
lload  head.lnd 
gload  pasgt.g 
lload  pasgt.lnd 
cload  head.pasgt.cdd 
lload  head.pasgt.lnd 
hide 

Register  3  1 
zregister  2  3 
2 

movie_seg  - 
land  off 
shrink  9.4  0  0 
1 

movie_seg  lyl  10 
hide  1 

clearance  4  .5  12.5  head.results 
gwrite  head.pasgt.fail.g 
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FILES  NEEDED  FOR  TUTORIAL_7 


SCRIPT  FILE  (S)  IMAGE  FILE(S)  COLOR  FILE(S)  MATRIX  FILE(S) 

m2.1c,  m2.2c,  m2.3c, 
m2.4c,  m2.5c,  m2.6c, 
m2.7c,  m2.8c,  m2.9c, 
m2.I0c,  m2.11c,  m2.12c, 
m2. 13c,  m2. 14c,  m2. 15c, 
m2.16c,  m2.17c,  m2.18c, 
m2. 19c, 

m2.1cs,  m2.2cs,  m2.3cs, 
m2.4cs,  m2.5cs,  m2.6cs, 
m2.7cs,  m2.8cs,  m2.9cs, 
m2.10cs,  m2. lies,  m2.12cs, 
m2.13cs,  m2.14cs,  m2.15cs, 
m2.16cs,  m2.17cs,  m2.18cs, 
m2.19cs 

SCRIPT  FILE  FOR  TUTORIAL_7 

option  wireframe  off 
option  surface  on 
cloads  -a  m2.1c 
cloads  -a  m2.2c 
cloads  -a  m2.3c 
cloads  -a  m2.4c 
cloads  -a  m2.5c 
cloads  -a  m2.6c 
cloads  -a  m2.7c 
cloads  -a  m2.8c 
cloads  -a  m2.9c 
cloads -a  m2. 10c 
cloads  -a  m2. 11c 
cloads  -a  m2. 12c 
cloads  -a  m2. 13c 
cloads  -a  m2. 14c 
cloads  -a  m2. 15c 
cloads  -a  m2. 16c 
cloads  -a  m2. 17c 
cloads  -a  m2. 18c 
cloads  -a  m2. 19c 

*  link  the  parts  of  a  stereo  subject  together 

*  parts  must  be  linked  (at  least  right  now)  from  the  outside  in 

* 

*  head  and  neck 
super  link  2  1 
super  link  3  2 

*  right  arm 


tutorial_7 

cs 

linkl 

sitl 
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super  link  7  8 
super  link  6  7 
super  link  3  6 

*  left  arm 
super  link  10  11 
super  link  9  10 
super  link  3  9 

*  right  leg 
super  link  14  15 
super  link  13  14 
super  link  12  13 
super  link  5  12 

*  left  leg 
super  link  18  19 
super  link  17  18 
super  link  16  17 
super  link  5  16 

*  lower  torso 
super  link  4  5 
super  link  3  4 

*  move  the  segments  of  the  body  into  a  seated  position 

*  segment  3  is  torso  to  which  all  other  parts  are  anchored 
3 

move  0  -80 

*  slightly  bend  torso  at  waist 

5 

rotate  -10 

*  rotate  legs 
12 

rotate  -80 
14 

rotate  90 
16 

rotate  -80 
18 

rotate  90 

*  rotate  arms 

6 

rotate  0  30 

7 

rotate  -90 

8 

rotate  0-1 10 

9 

rotate  0  -30 

10 

rotate  -90 
11 

rotate  0  70 
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right 

3 

rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
rotate  0  30 
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FILES  NEEDED  FOR  TUTORIAL_8 

SCRIPT  FILE  IMAGE  FILE(S)  COLOR  FILE(S) 

tutorial_8  dr_boff.g 

fbsetup 

SCRIPT  FILE  FOR  TUTORIAL_8 

axes  off 
boxes  off 
fkeys  off 
@  fbsetup 
gload  dr_boff.g 
mload  std.mtx 
eye  3700 
pick  on 
move  100  70 
points  off 
surface  on 
surface  off 
points  on 
movie_seg  uz-234 
1 

movie_seg  lz260 
1 

movie_seg  ly610 
1 

movie_seg  lyl20  uy609  lz-233  uz259 
1 

movie_seg  uyl  19  lz-233  uz259 
hide  1 
2 

move  0  0  -50 

3 

move  0  0  50 

4 

move  0  50 
6 

move  0  -50 


MATRIX  FILE(S) 
std.mtx 
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FILES  NEEDED  FOR  TUTORIAL_9 

SCRIPT  FILE  (S)  IMAGE  FILE(S)  COLOR  FILE(S) 

tutorial_9  tsa_stda.p]y 

c50x25.g  calipers. g.color 

SCRIPT  FILE  FOR  TUTORIALS 


MATRIX  FTLE(S) 
std2.mtx,  waist_circ.mtx 
caliper.mtx 


rgb  on 
gouraud  on 
option  wireframe  off 
option  points  off 
option  surface  on 
pload  tsa_stda.ply  -1000 
mload  std2.mtx 
gload  c50x25.g 
fullcolor  calipers.g 
calipers  on 
mload  caliper.mtx 
jaw  2  150 
top 

autojaws  1 
walls  640  643 
walls  full 
right 

movie_seg  uy40  ly-20 
hide  1 
hide  2 
top 

mload  waist_circ.mtx 

resample 

hide  3 

pick  on 

pickmode  cir3p 
top 

surface 
distance  2 
tape  3 
distance  2 
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FILES  NEEDED  FOR  TUTORIAL_10 

SCRIPT  FILE  (S)  IMAGE  FILE(S)  LANDMARK  FELE(S) 

tutorial_10  chrisla.ply  chrisla.lnd 

SCRIPT  FILE  FOR  TUTORIAL_10 

pload  chrisla.ply  -1000 
mload  std.mtx 
pload  chrisla.ply  -1000 
mload  std.mtx 
lload  chrisla.lnd 
split  11  z72  z64 
1 

copyland  11  2 II 
copyland  12  2  z24 
add_to_land  12  0  -25  51 
copyland  13  2  z43 
add_to_land  13  0  0  51 
copyland  14  2  z46 
add_to_land  14  0  0  5 1 
copyland  15  2  z74 
add_to_land  15  38  -38  0 
2 

split  16  z52  z51 
1 

copyland  16  2  16 
2 

split  17  z21  z54 
1 

copyland  17  2 17 
copyland  18  2  z66 
add_to_land  18  -38  -38  0 
2 

split  19  z57  z58 
1 

copyland  19  2 19 
2 

split  110  z23  z60 
2 

split  11  Iz24zl7 
1 

copyland  111  2  111 
2 

split  112  z35  z36 
1 

copyland  112  2 112 
2 


MATRIX  FILE(S) 
std.mtx 
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split  113  z38  z78 
1 

copyland  113  2  113 
2 

split  114  z24 118 
1 

copyland  114  2  114 
2 

split  115  z27  z28 
1 

copyland  115  2 115 
2 

split  116  z30  z70 
1 

copyland  116  2 116 
2 

hide 

1 

wireframe 

surface 

transparent 
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APPENDIX  B 

HEAD  AND  FACE  ANATOMICAL  LANDMARKS: 
DESCRIPTIONS  AND  ILLUSTRATIONS 
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ANATOMICAL  LANDMARK  DEFINITIONS 


CHEILION:  the  comers  of  the  mouth  formed  by  the  juncture  of  the  lips. 

ECTOCANTHUS:  the  outer  comers  of  the  eyes;  the  lateral  canthus 
ENDOCANTHUS:  the  inner  comers  of  the  eyes;  the  medial  canthus 

FRONTOTEMPORALE:  The  point  of  deepest  indentation  of  the  temporal  crest  from  the  frontal  bone 
above  the  browridges. 

GLABELLA:  Landmark  title  for  the  most  forward  point  in  the  midline  of  the  forehead  between  the  brow 
ridges. 

GONION:  A  comer  of  the  jaw;  the  lateral  point  of  the  comer  of  the  mandible  (jaw  bone). 

INFRAMALAR:  The  most  inferior  point  of  the  zygomatic  process  of  the  maxilla. 

INFRAORBITALE:  The  lowest  point  on  the  inferior  margin  of  the  orbit  or  eye  socket. 

INFRAZYGION:  The  inferior  border  of  the  zygomatic  arch  directly  below  zygion. 

MENTON  (LANDMARK):  Title  for  the  inferior  point  of  the  mandible  (tip  of  the  chin)  in  the 
midsagittal  plane. 

NUCHALE:  The  lowest  bony  point  on  the  base  of  the  back  of  the  skull  in  the  mid-sagittal  plane. 

PROMENTON:  The  most  anterior  projection  of  the  soft  tissue  of  the  chin  in  the  midsagittal  plane. 
PRONASALE  (LANDMARK):  Title  for  the  tip  of  the  nose. 

PUPIL:  The  center  of  the  contractile  (usually  round)  aperture  in  the  iris  of  the  eye;  the  center  of  the 
pupil. 

SELLION:  The  point  of  greatest  indentation  of  the  nasal  root  depression,  (the  point  of  greatest 
indentation  where  the  bridge  of  the  nose  meets  the  forehead.) 

STOMION:  The  point  of  contact  between  the  upper  and  lower  lips  in  the  midsagittal  plane. 
SUBMANDIBULAR:  Under  the  mandible  or  lower  jaw. 

SUBNASALE:  The  point  inferior  to  the  nose  where  the  base  of  the  nasal  septum  meets  the  philtrum;  the 
point  of  the  intersection  of  the  groove  of  the  upper  lip  (philtrum)  with  the  inferior  surface  of  the  nose  in 
the  midsagittal  plane. 
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SUPRAECTOCANTHUS:  The  most  protruding  point  of  the  browridge  located  on  the  same  vertical  axis 
as  ectocanthus. 

SUPRAENDOCANTHUS:  The  most  protruding  point  of  the  browridge  located  on  the  same  vertical  axis 
as  ectocanthus. 

SUPRAMENTON:  The  point  of  greatest  indentation  of  the  mandibular  symphysis. 

SUPRAPUPIL:  The  most  protruding  point  of  the  browridge  located  on  the  same  vertical  axis  as  the 
corresponding  right  or  left  pupil. 

TRAGION:  point  located  at  the  notch  just  above  the  tragus  of  each  ear.  this  point  corresponds 
approximately  to  the  upper  edge  of  the  ear  hole  (external  auditory  meatus)  of  the  skull. 

ZYGION:  the  lateral  point  of  the  zygomatic  arch. 

ZYGOFRONTALE:  the  most  lateral  point  of  the  frontal  bone  where  it  forms  the  upper  margin  of  the 
bony  eye  socket. 
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APPENDIX  C 

WHOLE  BODY  ANATOMICAL  LANDMARKS: 
DESCRIPTIONS  AND  ILLUSTRATIONS 
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3-D  Landmark  List  for  Comfortable  Standing 
Posture  as  of  17  September  1997. 


# 

Segment 

Landmarks 

Method 

Front  1) 

Head 

Sellion 

scanned 

2) 

Inf raorbi tale 

(L) 

scanned 

3) 

Tragion 

(L) 

scanned 

4) 

Gonion 

(L) 

scanned 

5) 

Supramenton 

scanned 

6) 

Infraorbitale 

(R) 

scanned 

7) 

Gonion 

(R) 

scanned 

8) 

Tragion 

(R) 

scanned 

9) 

Thorax 

Suprasternale 

scanned 

10) 

Clavicale 

(L) 

scanned 

11) 

Clavicale 

(R) 

scanned 

12) 

Acromion 

(R) 

scanned 

13) 

Acromion 

(L) 

scanned 

14) 

Anterior  Axilla 

Ref.  Point 

(L) 

scanned 

15) 

Thelion/Bustpoint 

(L) 

scanned 

16) 

Substernale 

scanned 

17) 

Thelion/Bustpoint 

(R) 

scanned 

18) 

Anterior  Axilla 

Ref.  Point 

(R) 

scanned 

19) 

Tenth  Rib 

(R) 

scanned 

20) 

Tenth  Rib 

(L) 

scanned 

21) 

Pelvis 

Illocristale 

(R) 

scanned 

22) 

Illocristale 

(L) 

scanned 

23) 

ASIS 

(R) 

scanned 

24) 

ASIS 

(L) 

scanned 

25) 

Trochanter ion 

(R) 

scanned 

26) 

Trochanter ion 

(L) 

scanned 

27) 

Crotch 

calculated 

28) 

Wrist 

Radial  Styloid 

(R) 

scanned 

29) 

Hand 

Metacarpal -Phalangeal  II 

scanned 

30) 

Dactyl ion 

(R) 

scanned 

31) 

Wrist 

Radial  Styloid 

(L) 

scanned 

32) 

Hand 

Metacarpal-Phalangeal  II 

(L) 

scanned 

33) 

Dactyl ion 

(L) 

scanned 

34) 

Thigh 

Lateral  Femoral 

Epicondyle 

(L) 

scanned 

35) 

Medial  Femoral 

Epicondyle 

(L) 

scanned 

36) 

Medial  Femoral 

Epicondyle 

(R) 

scanned 

37) 

Lateral  Femoral 

Epicondyle 

(R) 

scanned 

38) 

Ankle 

Medial  Malleolus 

(R) 

scanned 

39) 

Sphyrion 

(R) 

scanned 
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40) 

Foot 

Metatarsal -Phalangeal  I 

(R) 

scanned 

41) 

Phalange  II  (Foot) 

(R) 

scanned 

42) 

Metatarsal -Phalangeal  V 

(R) 

scanned 

43) 

Ankle 

Medial  Malleolus 

(L) 

scanned 

44) 

Sphyrion 

(L) 

scanned 

45) 

Foot 

Metatarsal -Phalangeal  I 

(L) 

scanned 

46) 

Phalange  II  (Foot) 

(L) 

scanned 

47) 

Metatarsal-Phalangeal  V 

(L) 

scanned 

Back  48) 

Head 

Nuchale 

scanned 

49) 

Cervicale  (Spinel) 

scanned 

50) 

Thorax 

Posterior  Axilla  Ref.  Point (L) 

scanned 

51) 

Posterior  Axilla  Ref.  Point (R) 

scanned 

•  52) 

Tenth  Rib  Midspine  (Spine 

II) 

scanned 

53) 

Pelvis 

PSIS  (L) 

scanned 

54) 

PSI  Midspine 

calculated 

55) 

PSIS  (R) 

scanned 

56) 

Preferred  Waist  Posterior 

scanned 

57) 

Arm 

Lateral  Humeral  Epicondyle 

(L) 

scanned 

58) 

Radiale  (L) 

scanned 

59) 

Olecranon  (L) 

scanned 

60) 

Medial  Humeral  Epicondyle 

(L) 

scanned 

61) 

Medial  Humeral  Epicondyle 

(R) 

scanned 

62) 

Olecranon  (R) 

scanned 

63) 

Lateral  Humeral  Epicondyle 

(R) 

scanned 

64) 

Radiale  (R) 

scanned 

65) 

Wrist 

Ulnar  Styloid  (R) 

scanned 

66) 

Hand 

Metacarpal-Phalangeal  V 

(R) 

scanned 

67) 

Wrist 

Ulnar  Styloid  (L) 

scanned 

68) 

Hand 

Metacarpal-Phalangeal  V 

(L) 

scanned 

69) 

Thigh 

Knee  Crease  (L) 

scanned 

70) 

Knee  Crease  (R) 

scanned 

71) 

Ankle 

Lateral  Malleolus 

(R) 

scanned 

72) 

Foot 

Posterior  Calcaneous 

(R) 

scanned 

73) 

Posterior  Calcaneous 

(L) 

scanned 

74) 

Ankle 

Lateral  Malleolus 

(L) 

scanned 

-Note  these  landmarks  are  subject  to  change. 
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APPENDIX  D 


LANDMARK  FILES:  ANATOMICAL  AND  AUXILIARY  LANDMARKS 

FOR  THE  HEAD  AND  FACE 
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SUBJECTJD  =  010_53p 
SCAN_TYPE  =  NO  TYPE 
STUDY_NAME  =  *  *  *  NO  STUDY  *  *  * 

LAND_STUDY  =  New  Study 
STD_LAND  =  42 
AUX_LAND  =  0 
STANDARD  = 

1  371  116  72.66  -11.54  181.31  -71.74  Right  Tragion 

2  343  124  74.03  -35.69  193.81  -64.86  Right  Zygion 

3  344  118  72.86  -34.34  184.43  -64.26  Right  Infra  Zygion 

4  346  78  55.40  -24.91  121.91  -49.49  Right  Gonion 

5  283  67  68.70  -64.97  104.72  -22.35  Right  Mid  Infra  Mandibular 

6  299  153  83.38  -72.03  239.14  -41.99  Right  Frontotemporale 

7  297  146  86.20  -75.52  228.20  -41.57  Right  Zygofrontale 

8  280110  90.75  -86.84  171.93  -26.35  Right  Infra  Malar 

9  288  137  80.96  -74.80  214.13  -30.99  Right  Ectocanthus 

10.259  138  75.82  -75.77  215.69  -2.79  Right  Endocanthus 

11  281  129  84.46  -80.52  201.63  -25.51  Right  Infraorbitale 

12  237  161  89.27  -86.86  251.64  20.62  Glabella 

13  237  143  93.29  -90.76  223.51  21.55  Sellion 

14  233  122  117.98-113.31  190.69  32.85  Pronasale 

15  234  111  102.96  -99.23  173.49  27.46  Subnasale 

16  234  75  106.66-102.80  117.22  28.44  Promenton 

17  231  65  92.67  -88.35  101.60  27.98  Menton 

18  257  93  96.21  -96.20  145.36  -1.18  Right  Chelion 

19  234  96  106.02-102.18  150.05  28.27  Stomion 

20  216  94  99.29  -87.57  146.92  46.80  Left  Chelion 

21  234  53  58.81  -56.68  82.84  15.68  Submandibular 

22  196130  84.98  -62.97  203.19  57.07  Left  Infraorbitale 

23  215  138  75.36  -66.02  215.69  36.34  Left  Endocanthus 

24  186  137  80.62  -52.66  214.13  61.04  Left  Ectocanthus 

25  182  70  68.10  -41.90  109.41  53.69  Left  Mid  Infra  Mandibular 

26  176154  84.04  -46.69  240.70  69.88  Left  Frontotemporale 

27  175  148  85.42  -46.58  231.32  71.60  Left  Zygofrontale 

28  189  110  91.67  -62.39  171.93  67.16  Left  Infra  Malar 

29  132123  77.00  -3.78  192.25  76.91  Left  Zygion 

30  133  117  76.22  -4.68  182.87  76.08  Left  Infra  Zygion 

31  128  81  61.23  0.00  126.60  61.23  Left  Gonion 

32  108  118  74.80  18.17  184.43  72.56  Left  Tragion 

33  495  93  85.38  83.53  145.36  -17.68  Nuchale 

34  271  139  80.98  -79.62  217.26  -14.83  Right  Pupil 

35  286  148  88.59  -82.65  231.32  -31.89  Right  SupraEctocanthus 

36  269  153  86.10  -85.01  239.14  -13.68  Right  SupraPupil 

37  256  150  87.00  -87.00  234.45  0.00  Right  SupraEndocanthus 

38  203  140  84.67  -67.39  218.82  51.27  Left  Pupil 

39  192  150  88.79  -62.79  234.45  62.78  Left  SupraEctocanthus 

40  205  153  89.22  -72.31  239.14  52.26  Left  SupraPupil 

41  219  150  87.33  -78.48  234.45  38.30  Left  SupraEndocanthus 

42  234  87  104.15-100.38  135.98  27.78  SupraMenton 
AUX  = 

END  = 


152 


SUBJECTED  =  010_53ph 
SCAN_TYPE  =  NO  TYPE 
STUDY_NAME  =  *  *  *  NO  STUDY  *  *  * 

LANDJSTUDY  =  New  Study 
STDJLAND  =  42 
AUX_LAND  =  6 
STANDARD = 

1- 999-999  0.00  0.00  0.00  0.00 

2- 999-999  0.00  0.00  0.00  0.00 

3- 999-999  0.00  0.00  0.00  0.00 

4- 999-999  0.00  0.00  0.00  0.00 

5  -999  -999  0.00  0.00  0.00  0.00 

6  279  130  109.69-105.35  203.19  -30.55  Right  Frontotemporale 

7  280123  109.70-104.98  192.25  -31.85  Right  Zygofrontale 

8  271  86  109.52-107.67  134.42  -20.05  Right  Infra  Malar 

9- 999-999  0.00  0.00  0.00  0.00 

10- 999-999  0.00  0.00  0.00  0.00 

11  268  104  107.21  -106.05  162.55  -15.74  Right  Infraorbitale 

12  232  130  123.92-118.59  203.19  35.97  Glabella 

13  232  114  121.49-116.26  178.18  35.26  Sellion 

14  231  90  136.23-129.87  140.67  41.14  Pronasale 

15-999-999  0.00  0.00  0.00  0.00 

16  231  49  111.87-106.65  76.59  33.78  Promenton 

17- 999-999  0.00  0.00  0.00  0.00 

18- 999-999  0.00  0.00  0.00  0.00 

19  -999  -999  0.00  0.00  0.00  0.00 

20- 999-999  0.00  0.00  0.00  0.00 

21- 999-999  0.00  0.00  0.00  0.00 

22  201  105  106.89  -83.45  164.12  66.79  Left  Infraorbitale 

23  -999  -999  0.00  0.00  0.00  0.00 

24- 999-999  0.00  0.00  0.00  0.00 

25- 999-999  0.00  0.00  0.00  0.00 

26  185  128  111.11  -71.54  200.06  85.02  Left  Frontotemporale 

27  185  121  111.76  -71.96  189.12  85.51  Left  Zygofrontale 

28  192  88  109.96  -77.76  137.54  77.75  Left  Infra  Malar 

29  -999  -999  0.00  0.00  0.00  0.00 

30- 999-999  0.00  0.00  0.00  0.00 

31- 999-999  0.00  0.00  0.00  0.00 

32- 999-999  0.00  0.00  0.00  0.00 

33  -999  -999  0.00  0.00  0.00  0.00 

34- 999-999  0.00  0.00  0.00  0.00 

35- 999-999  0.00  0.00  0.00  0.00 

36- 999-999  0.00  0.00  0.00  0.00 

37- 999-999  0.00  0.00  0.00  0.00 

38  -999  -999  0.00  0.00  0.00  0.00 

39- 999-999  0.00  0.00  0.00  0.00 

40- 999-999  0.00  0.00  0.00  0.00 

41  -999  -999  0.00  0.00  0.00  0.00 

42-999-999  0.00  0.00  0.00  0.00 

AUX  = 

1  387  122  121.91  4.49  190.69  -121.83  Helmet  LAND  1 

2  354  94  115.02  -41.39  146.92 -107.32  Helmet  LAND  2 

3  233  171  123.48-118.60  267.27  34.39  Helmet  LAND  3 
4115  92  114.98  18.26  143.80  113.52  Helmet  LAND  4 
5  83  118  122.87  64.46  184.43  104.61  Helmet  LAND  5 
6493  80  107.78  104.87  125.04  -24.90  Helmet  LAND  6 
END  = 
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APPENDIX  E 

LANDMARK  FILES:  ANATOMICAL  LANDMARKS 
FOR  THE  WHOLE  BODY 
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SUBJECTED  =  vstemplate.ply 
SCAN_TYPE  =  NO  TYPE 
STUDY.NAME  =  *  *  *  NO  STUDY  *  *  * 
LANDJSTUDY  =  New  Study 
STD_LAND  =  42 
AUX_LAND  =  80 
STANDARD  = 


1 

999 

999 

0.00 

0.00 

0.00 

0.00 

2 

999 

999 

0.00 

0.00 

0.00 

0.00 

3 

999 

999 

0.00 

0.00 

0.00 

0.00 

4 

999 

999 

0.00 

0.00 

0.00 

0.00 

5 

999 

999 

0.00 

0.00 

0.00 

0.00 

6 

999 

999 

0.00 

0.00 

0.00 

0.00 

7 

999 

999 

0.00 

0.00 

0.00 

0.00 

8 

999 

999 

0.00 

0.00 

0.00 

0.00 

9 

999 

999 

0.00 

0.00 

0.00 

0.00 

10 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

11 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

12 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

13 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

14 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

15 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

16 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

17 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

18 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

19 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

20 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

21 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

22 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

23 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

24 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

25 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

26 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

27 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

28 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

29 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

30 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

31 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

32 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

33 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

34 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

35 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

36 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

37 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

38 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

39 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

40 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

41 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

42 

-999 

-999 

0.00 

0.00 

0.00 

0.00 

AUX  = 

1  91120  760.65  -83.94  -72.12  756.00  =>Glabella 

2  9  223  742.99  -85.97  -73.61  738.00  Sellion 

3  8  11907  652.58  -92.41  -78.25  646.00  Supramenton 

4  815324  720.05  -93.12  -44.83  714.00  Rt  Infraorbit. 

5  8  15343  716.11  -54.99  -93.33  714.00  Lt  Infraorbit. 

6  8  8413  552.65  -26.85  -28.16  552.00 ->Neck  Base 

7  8  5221  506.61  -24.87  -25.82  506.00  Suprastemale 

8  8  5742  513.90  -44.11  -4.06  512.00  Rt  Clavicale 

9  8  5755  512.16  -12.85  -53.16  512.00  Lt  Clavicale 

10  7  187  313.17  -75.23  -62.18  304.00  =>Substemale 

11  76193  375.15-118.33  23.95  356.00 Rt Thelion 

12  7  6229  356.04  -5.33-138.36  356.00  Lt  Thelion 

13  6  4307  230.59-118.18  35.77  198.00  Rt  Tenth  Rib 

14  6  3182  189.26  -21.82-126.45  188.00  Lt  Tenth  Rib 

15  5  9603  143.82  -99.34  103.25  104.00  =>Rt  Illocrist. 

16  5  10711  125.86  53.34-121.67  114.00 Ltlllocrist. 

17  5  1623  148.37-143.93  32.80  36.00  RtASIS 

18  5  1668  39.65  -16.60-142.01  36.00  LtASIS 


19  5  227  113.76-111.20  -70.75  24.00  Pref  Waist  Ant. 

20  3  13342  284.22-248.47  238.98  -138.00  =>Rt  MC  Phal  II 

21  4  6410  187.71  -176.46  273.02  -64.00  Rt  Ulnar  Styloid 

22  3  12831  210.52  155.42 -326.23 -142.00  LtMC  Phal  II 

23  4  8060  213.18  207.71  -280.52  -48.00  Lt  Ulnar  Styloid 

24  3  8211  186.68  -56.26  -25.56 -178.00  =>Crotch 

25  4  6801  158.16-146.34  46.76  -60.00  Hip  Circ  Max  Ht 

26  1  16324  460.82  27.47  -83.32  -460.00  =>Lt  Suprapatella 

27  1  14108  497.85  88.07  -84.26  -490.00  Lt  Lat  Fem  Epic. 

28  1  14723  483.67  40.12  -20.84 -482.00  Lt  Med  Fem  Epic. 

29  1  11665  527.69  42.24  -41.15 -526.00  LtTibiale 

30  0  6105  924.70  36.08  -23.39 -924.00  =>Lt  Med  Malleolus 

31  0  5228  940.55  32.02  -28.45 -940.00  Lt  Sphyrion 

32  0  1405  988.65  -35.74 -126.23 -988.00  Lt  MP  1 

33  0  576  996.24  -22.04  -205.35  -996.00  Lt  Digit  II 

34  1  16249  468.56  -78.15  61.20 -462.00  =>Rt  Suprapatella 

35  1  13929  497.67  -60.30  120.38 -494.00  Rt  Lat  Fem  Epic. 

36  1  14530  486.13  -11.40  57.12 -486.00  Rt  Med  Fem  Epic. 

37  1  11611  528.48  -22.52  65.87  -528.00  RtTibiale 

38  0  6159  924.02  -5.91  47.93 -924.00  =>Rt  Med  Malleolus 

39  0  5298  940.02  -5.33  49.90 -940.00  Rt  Sphyrion 

40  0  1828  993.54-137.32  14.40 -984.00  Rt  MP  I 

41  0504  1017.27-206.93  54.10 -996.00  Rt  Digit  II 

42  8  9365  577.96  47.50  31.76  576.00  =>Cervicale 

43  7  7243  376.27  87.32  57.90  366.00  Scapula  Pt  spine 

44  7  4733  345.08  27.23  196.85  344.00  =>Rt  Axilla 

45  7  5147  397.57  195.83  -60.77  346.00  =>Lt  Axilla 

46  6  4716  211.05  61.13  44.40  202.00  =>Ten  Rib  Mid-Spine 

47  5  5823  95.04  62.04  55.98  72.00  Pref  Waist  Pos. 

48  5  4886  68.45  24.27  100.58  64.00  RtPSIS 

49  5  5581  108.89  83.41  19.02  70.00  LtPSIS 

50  6  3436  197.46  -53.78  204.06  190.00  =>Rt  Olecranon 

51  6  4841  233.15-116.42  241.86  202.00  Rt  Lat  Hum  Epic. 

52  6  1555  183.40  -57.97  193.95  174.00  Rt  Med  Hum  Epic. 

53  6  2518  215.48-115.36  244.57  182.00  RtRadiale 

54  4  7813  233.11  -227.24  239.70  -52.00  =>Rt  Radial  Styloid 

55  3  14379  210.46-165.51  269.48 -130.00  Rt  MC  Phal  V 

56  6  4878  294.41  212.27-184.56  204.00  =>Lt  Olecranon 

57  6  6505  279.01  174.13-237.61  218.00  Lt  Lat  Hum  Epic. 

58  6  3508  242.53  148.18-171.81  192.00  Lt  Med  Hum  Epic. 

59  6  4180  273.41  188.55-231.61  198.00  Lt  Radiale 

60  4  7844  160.76  152.78-308.71  -50.00  =>Lt  Radial  Styloid 

61  3  15533  254.19  224.08  -273.82  -120.00  Lt  MC  Phal  V 

62  0  3621  965.27  49.55  1 16.86  -964.00  =>Rt  Calcaneous 

63  0  4435  959.48  119.53  15.59 -952.00  =>Lt  Calcaneous 

64  8  14880  706.32  21.31  -79.66  706.00  =>Lt  Tragion 

65  8  12045  648.00  -0.91  -76.92  648.00  Lt  Gonion 

66  8  5970  539.07  156.02-149.12  516.00  =>Lt  Acromion 

67  3  2465  302.95  203.96  -315.13  -224.00  =>Lt  Dactylion 

68  4  7823  198.60  192.21  -308.34  -50.00  Lt  Wrist  Land. 

69  4  8786  103.54  94.64-125.04  -42.00  Lt  Trocanterion 

70  0  5971  932.70  111.57  -35.40  -926.00  =>Lt  Lat  Malleolus 

71  0  1493  988.40  68.81  -155.17  -986.00  Lt  MP  V 

72  8  15189  714.89  -64.23  25.03  712.00  =>Rt  Tragion 

73  8  12006  651.90  -71.18  15.29  648.00  Rt  Gonion 

74  8  5176  512.75  -82.94  186.38  506.00  =>Rt  Acromion 

75  3  1 1 15  331.16  -230.27  245.98  -238.00  =>Rt  Dactylion 

76  4  6651  221.41  -212.55  269.68  -62.00  Rt  Wrist  Land. 

77  4  9336  120.98-114.86  127.23  -38.00  Rt  Trocanterion 

78  0  6038  926.03  -7.37  123.00 -926.00  =>Rt  Lat  Malleolus 

79  0  1322  996.61  -130.71  118.13 -988.00  Rt  MP  V 

80  0  7654  892.02  -5.17  121.93 -892.00  Ankle  Circ  Min. 

END  = 
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APPENDIX  F 

COMMANDS:  FUNCTIONALITY  FOR  HEAD  AND  WHOLE  BODY 

IMAGE  DATA 
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COMMAND 

Works  With 

I 

Yes 

$ 

Yes 

@ 

Yes 

abssub 

Yes 

add 

Yes 

add_to_land 

Yes 

addobj 

Yes 

align 

Yes 

alt_land 

Yes 

and 

Yes 

avgland 

Yes 

axes 

Yes 

back 

Yes 

balltest 

Yes 

black 

Yes 

bottom 

Yes 

bottom_cap 

Yes 

boxes 

Yes 

cd 

Yes 

center 

Yes 

centroid 

Yes 

circumference 

Yes 

clearance 

No 

cload 

Yes 

colors 

Yes 

comment 

Yes 

conclose 

Yes 

contour 

Yes 

contours 

Yes 

copy 

Yes 

copyland 

Yes 

copyseg 

Yes 

cursor 

Yes 

cwrite 

Yes 

cybermovie 

Yes 

delete 

Yes 

del land 

Yes 

delpnt 

Yes 

delseg 

Yes 

delta 

Yes 

derive 

Yes 

diff 

Yes 

dilate 

Yes 

displace 

No 

distance 

Yes 

do 

Yes 

drawline 

Yes 

erode 

Yes 

exit 

Yes 

eye 

Yes 

eyedist 

Yes 

f  cwrite 

Yes 

fill 

Yes 

filter 

Yes 

filtseg 

Yes 

f  ix__seam 

Yes 

fkeys 

Yes 

front 

Yes 

Cyberware?  Works  With 

Yes 
Yes 
Yes 
No 
No 
Yes 
No 
No 
Yes 
No 
No 
Yes 
Yes 
No 
Yes 
Yes 
No 
Yes 
Yes 
Yes 
Yes 
No 
Yes 
No 
Yes 
Yes 
No 
No 
Yes 
No 
Yes 
No 
No 
No 
No 
Yes 
Yes 
No 
No 
No 
Yes 
No 
No 
Yes 
No 
No 
Yes 
No 
Yes 
Yes 
Yes 
Yes 
No 
No 
No 
No 
Yes 
Yes 


•  g/ .ply/ . obj  ? 
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fullcolor 

Yes 

Yes 

gcv 

Yes 

No 

gload 

No 

Yes 

gouraud 

Yes 

Yes 

gwrite 

No 

Yes 

help 

Yes 

Yes 

hide 

Yes 

Yes 

histogram 

Yes 

No 

interpolate 

Yes 

No 

intrplnd 

Yes 

Yes 

jump 

Yes 

Yes 

land 

Yes 

Yes 

landlist 

Yes 

Yes 

left 

Yes 

Yes 

Hoad 

Yes 

Yes 

lregister 

Yes 

Yes 

lwrite 

Yes 

Yes 

man 

Yes 

Yes 

median 

Yes 

No 

merge 

Yes 

No 

mload 

Yes 

Yes 

modi and 

Yes 

Yes 

move 

Yes 

Yes 

move_vert  ex 

No 

Yes 

movie_segment 

No 

Yes 

mwrite 

Yes 

Yes 

name land 

Yes 

Yes 

negsub 

Yes 

No 

new_order 

Yes 

Yes 

newland 

Yes 

Yes 

option 

Yes 

Yes 

ortho 

Yes 

Yes 

pause 

Yes 

Yes 

pick 

Yes 

Yes 

pickmode 

Yes 

Yes 

planes 

Yes 

Yes 

pload 

No 

Yes 

points 

Yes 

Yes 

pop 

Yes 

Yes 

possub 

Yes 

No 

print 

Yes 

Yes 

push 

Yes 

Yes 

pwrite 

No 

Yes 

recolor 

Yes 

No 

refresh 

Yes 

Yes 

remark 

Yes 

Yes 

resample 

Yes 

Yes 

rgb 

Yes 

Yes 

right 

Yes 

Yes 

rotate 

Yes 

Yes 

ruin 

Yes 

No 

select. 

Yes 

Yes 

set 

Yes 

No 

shade 

Yes 

No 

shrink 

No 

Yes 

show 

Yes 

Yes 

side 

Yes 

Yes 

skip 

Yes 

Yes 

sleep 

Yes 

Yes 

smooth 

Yes 

No 

159 


split 

Yes 

No 

store 

Yes 

Yes 

subject 

Yes 

Yes 

super 

Yes 

Yes 

surface 

Yes 

Yes 

surface_area 

Yes 

Yes 

surf_reg 

No 

Yes 

tape 

Yes 

Yes* 

thin 

Yes 

No 

thres 

Yes 

No 

top 

Yes 

Yes 

tops 

Yes 

Yes 

toupee 

Yes 

No 

transparent 

Yes 

Yes 

trim 

Yes 

No 

volume 

Yes 

Yes 

walls 

Yes 

Yes 

white 

Yes 

Yes 

wireframe 

Yes 

Yes 

wload 

No 

Yes 

wwrite 

No 

Yes 

xload 

Yes 

No 

xwrite 

Yes 

No 

zload 

Yes 

No 

zregister 

Yes 

Yes 

zwrite 

Yes 

No 

*  contours  can  only  be  created  on  Cyberware  format,  but  zload  can  be  used  on 
movie. byu  format  after  creating  them  on  Cyberware  objects. 
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APPENDIX  G 


FILE  FORMATS:  DESCRIPTION  OF  IMAGE  DATA  FILES  SUPPORTED 


BY  INTEGRATE  VERSION  1.28 


File  Fonnats^Su£gorted_b^  £^JFGRATE_Versjon  2-28 


_F _ (^be£w^ej>£^ne_r  Format  _(new)_  Jall(?2  except  _WFi^£[iel  scanners) 

ASCII  header  with  lines  of  the  form  <keyword>=<value>\n 
Header  terminates  with  DATA=\n 

Binary  cylindrical  data,  2  bytes  per  radius.  First  radius  is  lonO  latO. 

2nd  radius  is  lonO  latl.  Typically  512  longitudes  and  256  latitudes,  but 
header  (NLG,  NLT)  is  final  authority.  Each  radius  is  multiplied  by  2  **  RSHIFT 
(value  from  header).  RSHIFT  is  typically  either  3  or  5.  Resulting  radius  value 
is  in  microns,  so  for  an  RSHIFT  of  3,  the  radius  is  multiplied  by  .008  to 
get  millimeters.  Longitude  proceeds  clockwise  (viewed  from  top)  and  latitude 
goes  from  bottom  to  top. 


IL _ Movie  .byu_^g_form at_ 

ASCII  file  with  4  sections; 

A.  Counts  Line 

cnpart  nvert  npoly  nedge> 

npart  -  number  of  different  parts  in  scene, 
nvert  -  number  of  vertex  points  in  scene, 
npoly  -  number  of  unique  polygons  in  scene, 
nedge  -  total  number  of  polygon  edges  in  scene 

B .  Part-scene  Definitions 
<polylfirst  poly  llast> 

poly  lfirst  -  index  of  first  polygon  in  first  scene  part 
(lowest  =1) 

poly  Hast  -  index  of  last  polygon  in  first  scene  part 
(highest  =  npoly) 

<polyNfirst  polyNlast>  (N  =  npoly) 

There  are  a  total  of  npart  lines  in  this  section, 
or  2  *  npart  indexes. 

C.  Vertex  Point  Coordinates  (x,  y,  z), 

3  coordinates  per  Vertex,  1  or  more  Vertices  per  line. 
There  are  a  total  of  nvert  Vertexs  (or  nvert  *  3  coordinates) 
listed  in  this  section. 

D.  Polygon  Definitions 

Polygons  are  defined  by  their  vertexes.  Edges  are  implied 
between  adjacent  vertexes  in  the  list,  and  between  the  last 
vertex  of  a  polygon  and  the  first  vertex  in  the  polygon. 

The  index  of  the  last  vertex  of  a  polygon  is  indicated  by 
negating  the  index.  The  lowest  vertex  index  is  1.  The 
largest  is  nvert.  There  are  a  total  of  nedge  vertexes 
listed  in  this  section.  There  should  be  a  total  of  npoly 
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negative  vertexes  (implying  separate  polygon  definitions). 
Example:  12-3  defines  a  triangle  using  vertices  1, 2,  and  3 

EL_  __  _  _W^efc^(^NLformat_  _ 

Refer  to  Wavefront  documentation/description. 

IV_ _ Several_variants  o^S^anfo^_j)ly_format_  _ 

This  complext  format  is  [no  longer?]  fully  documented  at  the  Stanford  Web  Site. 


V. _ CARD Jia^ASCTj>omt^ormat_(grid  and_non-grid)_  _ 

1.  Grid  format: 

GRID  <total_points>  <nlon>  <nlat>  <lonl>:<nlonn>  <latl>:<latn> 
<lon  lat  radius  xyz> 

<lon  lat  radius  x  y  z> 

2.  Non-Grid  format: 

CART  <totaLpoints> 

<x  y  z> 

<x  y  z> 

3 .  CARD  Lab  contour  file  format: 

CONT  <totaLpoints>  0  0  0:0  0:0 

<x  y  z>  [coordinates  for  1st  point  in  contour] 

<x  y  z>  [coordinates  for  last  point  in  contour] 


VI.  Old  CARD  Lab  Landmark  Files  Format 


5  1  1 

<lon  lat  radius  x  y  z>  for  standard  landmark  1 
<N>  1 

don  lat  radius  x  y  z>  for  standard  landmark  ‘N* 
-1  -1  -1  [end  of  file  tag] 


VII.  New  CARD  Lab  Landmark  File  Format 


SUB  JECTJD  =  <subject  identifier 
SCAN_TYPE  -  <type  identifier 
STUDY_NAME  =  <acquisition  study  identifier 
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LAND_STUDY  =  <1  and  mark  study  identifier 
STELLAND  =  42 

AUX_LAND  =  <N>  [number  of  auxiliary  landmarks  in  dataset] 
STANDARD  = 

1  <lon>  <lat>  <radius>  <x>  <y>  cz> 

42  <lon>  <lat>  <radius>  <x>  <y>  cz> 

AUX  = 

1  <lon>  <lat>  <radius>  <x>  <y>  <z>  <auxiliary  landmark  1  name> 

[N]  <lon>  <lat>  <radius>  <x>  <y>  <z>  <auxiliary  landmark  N  name> 
END  = 


Yin.  CARD  Lab  matrix  file  format 


coriginal  file  name> 

<original  subject  id  or  duplicate  of  file  name> 

<xl>  <yl>  <zl>  <tl>  [displacement  matrix] 

<x2>  <y2>  <z2>  <t2> 

<x3>  <y3>  <z3>  <t3> 

<x4>  <y4>  <z4>  <t4> 

THIN  <lon  thin>  <lat  thin>  [sub-sampling  intervals  on  Ion  and  lat] 

TRIM  clow  lon>  chigh  lon>  clow  lat>  chigh  lat>  [include  bounds  on  Ion  and  lat] 
CENTER  cx>  cy>  cz>  [displacement  (s)  from  original  object  center] 
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APPENDIX  H 

STEREOPHOTOGRAMMETRY:  USERS’  MANUAL  FOR 

STEREO_SLICE 
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Information  concerning  the  use  of  “Stereo  People”  data  with  INTEGRATE 


L _ Users’  Manual  for  STEREO_SLICE 


Stereo_Slice  is  a  program  which  extracts  datasets  from  the  CARD  Lab  “stereo 
people”  datasets  (cstereo.mal  and  cstereo.fem)  and  creates  datasets  which 
are  compatible  with  INTEGRATE.  It  creates  2  files  for  each  segment  in  the 
specified  dataset.  There  are  19  segments  in  each  dataset,  as  follows: 

1.  head 

2.  neck 

3.  thorax 

4.  abdomen 

5.  pelvis 

6.  right  upper  arm 

7.  right  lower  arm 

8.  right  hand 

9.  left  upper  arm 

10.  left  lower  arm 

11.  left  hand 

12.  right  upper  thigh 

13.  right  lower  thigh 

14.  right  lower  leg 

15.  right  foot 

16.  left  upper  thigh 

17.  left  lower  thigh 

18.  left  lower  leg 

19.  left  foot 

The  2  files  that  are  created  for  each  segment  are  {mlf}<subj#>.<segment#>c 
which  contains  cylindrical  coordinates  for  each  point  in  the  original  dataset, 
and  {mlf}<subj#>.<segment#>cs,  which  contains  a  centerpoint  for  each  slice 
in  the  cylindrical  coordinate  file.  Example:  f2.1c  is  radius  information  for 
the  head  segment  of  female  subject  2,  which  m5.2cs  contains  the  slice  centers 
for  the  neck  segment  for  male  subject  5.  This  format  allows  horizontal  slices, 
which  correspond  to  the  original  dataset  points,  but  allows  non- vertical 
center  axes  for  the  cylinder.  The  cylindrical  data  (c)  is  created  in  Cyberware 
Head  Scanner  or  Cyberware  Digitizer  Data  format,  while  the  centerpoint  data 
(cs)  is  an  ASCII  list  of  centerpoint  coordinates,  1  per  slice  in  the  segment 
of  the  original  dataset. 

Usage  of  STEREO_SLICE:  Stereo_Slice  requires  2  parameters:  the  gender  and 
subject  number  of  the  desired  dataset,  in  the  form  {mlf}<subj#>,  and  the 
number  of  longitudes  to  create  for  each  slice.  Stereo_Slice  also  requires 
that  the  2  stereo  data  files  (cstereo.mal  and  cstereo.fem)  be  either  in  the 
local  directory,  or  in  a  directory  specified  by  an  optional  3rd  parameter. 

On  CARD  Lab  System,  the  cstereo  files  are  in  /home/code/stereo. 

Example:  “stereo_slice  m2  32  /home/code/stereo”  creates  an  INTEGRATE- 
compatible  dataset  for  male  subject  2,  and  generates  32  points  for  each 
slice  of  data. 


II.  Use  of  Stereo  Data  With  INTEGRATE 
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After  StereoJSlice  has  been  used  to  extract  and  convert  the  data  for  a 
Stereo  dataset  into  an  INTEGRATE-compatible  format,  several  special 
considerations  are  needed  for  INTEGRATE  to  use  the  stereo  data. 

First,  INTEGRATE  needs  to  load  not  only  the  radius  files 
({mlf}<subj#>.<segment#>c),  but  also  the  centers  file 
({mlf}<subj#>.<segment#>cs).  There  is  a  slightly  different  form  of  the 
CLOAD  command  (CLOADS)  which  indicates  that  the  centers  file  is  also 
required.  The  CLOADS  command  works  identically  to  CLOAD,  except  that  it 
also  loads  the  centers  file. 

Second,  in  order  to  articulate  the  body  segments,  the  segments  must  be 

linked  together  using  the  “SUPER  LINK”  command.  The  SUPER  LINK  command 

connects  a  segment  to  another  segment  at  the  approximately  correct  anatomical 

point,  and  sets  the  center  of  rotation  of  the  subordinate  segment  at  the 

connection  point.  The  result  is  that  the  subordinate  segment  moves  along 

with  the  owning  segment  when  the  owning  segment  is  moved,  and  the  subordinate 

segment  rotates  around  the  connection  point  when  it  is  moved  individually. 

Except  for  the  lack  of  definition  of  anatomical  rotation  axes  and  limits, 
a  properly  linked  set  of  segments  can  be  articulated  in  a  fairly  natural 
way,  with  all  segments  responding  appropriately  to  movement  of  other 
segments.  There  are  several  INTEGRATE  script  files  which  simplify  the 
job  of  loading  and  linking  the  segments  of  a  stereo  dataset.  The  CS 
file  performs  the  CLOADS  command  for  each  of  the  19  body  segments  for 
the  specified  subject.  The  LINK1  script  links  the  body  segments  in  a 
hierarchy  starting  at  the  thorax,  assuming  that  the  segments  were  loaded 
as  INTEGRATE  objects  1-19.  Similarly,  the  LINK20  script  links  segments 
assuming  that  they  were  loaded  as  objects  20-38.  The  SIT1  and  SIT20  scripts 
demonstrate  articulation  by  rotating  a  subject  into  a  sitting  position, 
again  assuming  the  segments  are  objects  1-19  or  20-38. 
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APPENDIX  I 

DEFINITIONS  FOR  DETERMINATION  OF  JOINT  CENTERS 
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DEFINITIONS  FOR  DETERMINATION  OF  JOINT  CENTERS 


Ankles,  right  and  left:  midpoint  between  Lateral  Malleolus  and  Sphyrion 

Knees,  right  and  left:  midpoint  between  Lateral  Femoral  Condyle  and  Medial  Femoral  Condyle 

Hips,  right  and  left:  1.)  midpoint  between  Anterior  Superior  Iliac  Spine  (ASIS)  and  Symphysion 

2. )  translate  to  x  coordinate  (fore-aft)  of  the  Trochanterion 

3. )  translate  15  mm  down  in  the  z  direction  (vertical) 

Pelvic  Joint:  1 .)  use  Posterior  Superior  Iliac  Midspine  coordinates 
2.)  translate  51  mm  in  the  x  direction  (forward) 

Abdomen  Joint:  1.)  use  10th  Rib  Midspine  coordinates 

2.)  translate  51  mm  in  the  x  direction  (forward) 

Thorax  Joint:  1.)  use  Cervicale  coordinates 

2.)  translate  51  mm  in  the  x  direction  (forward) 

3.)  translate  25  mm  down  in  the  z  direction  (vertical) 

Head/Neck  Joint:  midpoint  between  right  and  left  Tragions 


Shoulder,  right  and  left:  1.)  use  Acromiale  coordinates 

2. )  translate  38  mm  toward  the  body  (y  direction) 

3. )  translate  38  mm  down  in  the  z  direction  (vertical) 

Elbow,  right  and  left:  midpoint  between  Medial  and  Lateral  Human  Epicondyles 
Wrist,  right  and  left:  midpoint  between  Radial  and  Ulnar  Styloid  Processes 
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